From 92ca88772a9c3eb1148c7a5f7b4da0ef018fef79 Mon Sep 17 00:00:00 2001 From: Jan Dvorak Date: Tue, 17 Aug 2021 12:34:00 +0200 Subject: [PATCH 01/45] Export collections for direct access --- package.js | 4 ++-- roles/roles_common.js | 2 ++ 2 files changed, 4 insertions(+), 2 deletions(-) diff --git a/package.js b/package.js index 90a65850..db587e81 100644 --- a/package.js +++ b/package.js @@ -22,10 +22,10 @@ Package.onUse(function (api) { api.use(['blaze@2.5.0'], 'client', { weak: true }) - api.export('Roles') + api.export(['Roles', 'RolesCollection', 'RoleAssignmentCollection']) api.addFiles('roles/roles_common.js', both) - api.addFiles('roles/roles_server.js', 'server') + api.mainModule('roles/roles_server.js', 'server') api.addFiles([ 'roles/client/debug.js', 'roles/client/uiHelpers.js', diff --git a/roles/roles_common.js b/roles/roles_common.js index c2aafa7c..6d2788b3 100644 --- a/roles/roles_common.js +++ b/roles/roles_common.js @@ -27,10 +27,12 @@ if (!Meteor.roles) { Meteor.roles = new Mongo.Collection('roles') } +export const RolesCollection = Meteor.roles if (!Meteor.roleAssignment) { Meteor.roleAssignment = new Mongo.Collection('role-assignment') } +export const RoleAssignmentCollection = Meteor.roleAssignment /** * @class Roles From e35a2a9eb0a645a9fbc7e483b6a5cab1de9a0ff2 Mon Sep 17 00:00:00 2001 From: Jan Dvorak Date: Sat, 8 Jul 2023 10:54:13 +0200 Subject: [PATCH 02/45] Switch collection assignment order --- roles/roles_common.js | 11 +++++++---- 1 file changed, 7 insertions(+), 4 deletions(-) diff --git a/roles/roles_common.js b/roles/roles_common.js index 6d2788b3..77b48101 100644 --- a/roles/roles_common.js +++ b/roles/roles_common.js @@ -24,15 +24,18 @@ * * @module Roles */ + +export const RolesCollection = new Mongo.Collection('roles') + if (!Meteor.roles) { - Meteor.roles = new Mongo.Collection('roles') + Meteor.roles = RolesCollection } -export const RolesCollection = Meteor.roles + +export const RoleAssignmentCollection = new Mongo.Collection('role-assignment') if (!Meteor.roleAssignment) { - Meteor.roleAssignment = new Mongo.Collection('role-assignment') + Meteor.roleAssignment = RoleAssignmentCollection } -export const RoleAssignmentCollection = Meteor.roleAssignment /** * @class Roles From 7ba9286029e1d8ea5c821bab7fd908f23282ef26 Mon Sep 17 00:00:00 2001 From: Jan Dvorak Date: Sat, 8 Jul 2023 10:55:16 +0200 Subject: [PATCH 03/45] Update versions --- package.js | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/package.js b/package.js index db587e81..787bcac6 100644 --- a/package.js +++ b/package.js @@ -2,13 +2,13 @@ Package.describe({ summary: 'Authorization package for Meteor', - version: '3.4.0', + version: '4.0.0', git: 'https://github.com/Meteor-Community-Packages/meteor-roles.git', name: 'alanning:roles' }) Package.onUse(function (api) { - api.versionsFrom(['1.12', '2.3']) + api.versionsFrom(['2.8']) var both = ['client', 'server'] @@ -20,7 +20,7 @@ Package.onUse(function (api) { 'check' ], both) - api.use(['blaze@2.5.0'], 'client', { weak: true }) + api.use(['blaze@2.7.1'], 'client', { weak: true }) api.export(['Roles', 'RolesCollection', 'RoleAssignmentCollection']) From 9896d70d57e634e195835c83a803d0c92682b084 Mon Sep 17 00:00:00 2001 From: Jan Dvorak Date: Sat, 8 Jul 2023 10:59:43 +0200 Subject: [PATCH 04/45] Use new collection variables in index creations --- roles/roles_server.js | 26 ++++++++++++++------------ 1 file changed, 14 insertions(+), 12 deletions(-) diff --git a/roles/roles_server.js b/roles/roles_server.js index 9a1857d8..58f4246b 100644 --- a/roles/roles_server.js +++ b/roles/roles_server.js @@ -1,20 +1,22 @@ /* global Meteor, Roles */ +import { RolesCollection, RoleAssignmentCollection } from './roles_common' + if (Meteor.roles.createIndex) { - Meteor.roleAssignment.createIndex({ 'user._id': 1, 'inheritedRoles._id': 1, scope: 1 }) - Meteor.roleAssignment.createIndex({ 'user._id': 1, 'role._id': 1, scope: 1 }) - Meteor.roleAssignment.createIndex({ 'role._id': 1 }) - Meteor.roleAssignment.createIndex({ scope: 1, 'user._id': 1, 'inheritedRoles._id': 1 }) // Adding userId and roleId might speed up other queries depending on the first index - Meteor.roleAssignment.createIndex({ 'inheritedRoles._id': 1 }) + RoleAssignmentCollection.createIndex({ 'user._id': 1, 'inheritedRoles._id': 1, scope: 1 }) + RoleAssignmentCollection.createIndex({ 'user._id': 1, 'role._id': 1, scope: 1 }) + RoleAssignmentCollection.createIndex({ 'role._id': 1 }) + RoleAssignmentCollection.createIndex({ scope: 1, 'user._id': 1, 'inheritedRoles._id': 1 }) // Adding userId and roleId might speed up other queries depending on the first index + RoleAssignmentCollection.createIndex({ 'inheritedRoles._id': 1 }) - Meteor.roles.createIndex({ 'children._id': 1 }) + RolesCollection.createIndex({ 'children._id': 1 }) } else { - Meteor.roleAssignment._ensureIndex({ 'user._id': 1, 'inheritedRoles._id': 1, scope: 1 }) - Meteor.roleAssignment._ensureIndex({ 'user._id': 1, 'role._id': 1, scope: 1 }) - Meteor.roleAssignment._ensureIndex({ 'role._id': 1 }) - Meteor.roleAssignment._ensureIndex({ scope: 1, 'user._id': 1, 'inheritedRoles._id': 1 }) // Adding userId and roleId might speed up other queries depending on the first index - Meteor.roleAssignment._ensureIndex({ 'inheritedRoles._id': 1 }) + RoleAssignmentCollection._ensureIndex({ 'user._id': 1, 'inheritedRoles._id': 1, scope: 1 }) + RoleAssignmentCollection._ensureIndex({ 'user._id': 1, 'role._id': 1, scope: 1 }) + RoleAssignmentCollection._ensureIndex({ 'role._id': 1 }) + RoleAssignmentCollection._ensureIndex({ scope: 1, 'user._id': 1, 'inheritedRoles._id': 1 }) // Adding userId and roleId might speed up other queries depending on the first index + RoleAssignmentCollection._ensureIndex({ 'inheritedRoles._id': 1 }) - Meteor.roles._ensureIndex({ 'children._id': 1 }) + RolesCollection._ensureIndex({ 'children._id': 1 }) } /* From e41a14a70a52d2f4da6604d12997cd48ec656ccc Mon Sep 17 00:00:00 2001 From: Jan Dvorak Date: Sat, 15 Jul 2023 12:17:58 +0200 Subject: [PATCH 05/45] Account for the new index creation method --- roles/roles_server.js | 17 ++--------------- 1 file changed, 2 insertions(+), 15 deletions(-) diff --git a/roles/roles_server.js b/roles/roles_server.js index 54d5416e..8c282e3c 100644 --- a/roles/roles_server.js +++ b/roles/roles_server.js @@ -1,18 +1,5 @@ /* global Meteor, Roles */ import { RolesCollection, RoleAssignmentCollection } from './roles_common' -let indexFnAssignment -let indexFnRoles - -if (Meteor.roles.createIndexAsync) { - indexFnAssignment = Meteor.roleAssignment.createIndexAsync.bind(Meteor.roleAssignment) - indexFnRoles = Meteor.roles.createIndexAsync.bind(Meteor.roles) -} else if (Meteor.roles.createIndex) { - indexFnAssignment = Meteor.roleAssignment.createIndex.bind(Meteor.roleAssignment) - indexFnRoles = Meteor.roles.createIndex.bind(Meteor.roles) -} else { - indexFnAssignment = Meteor.roleAssignment._ensureIndex.bind(Meteor.roleAssignment) - indexFnRoles = Meteor.roles._ensureIndex.bind(Meteor.roles) -} [ { 'user._id': 1, 'inheritedRoles._id': 1, scope: 1 }, @@ -20,8 +7,8 @@ if (Meteor.roles.createIndexAsync) { { 'role._id': 1 }, { scope: 1, 'user._id': 1, 'inheritedRoles._id': 1 }, // Adding userId and roleId might speed up other queries depending on the first index { 'inheritedRoles._id': 1 } -].forEach(index => indexFnAssignment(index)) -indexFnRoles({ 'children._id': 1 }) +].forEach(index => RoleAssignmentCollection.createIndexAsync(index)) +RolesCollection.createIndexAsync({ 'children._id': 1 }) /* From 5390b7e6f3453d630bca0fbfbeead9f7daa64119 Mon Sep 17 00:00:00 2001 From: Jan Dvorak Date: Sat, 15 Jul 2023 12:25:07 +0200 Subject: [PATCH 06/45] Add to history --- History.md | 4 ++++ 1 file changed, 4 insertions(+) diff --git a/History.md b/History.md index 7242730e..174e978c 100644 --- a/History.md +++ b/History.md @@ -1,5 +1,9 @@ # Changelog +## v4.0.0 + +* Collections are now directly exported from the package [#344](https://github.com/Meteor-Community-Packages/meteor-roles/pull/344) [@storytellercz](https://github.com/sponsors/StorytellerCZ) + ## v3.5.1 * Fix for index creation functions losing context [#371](https://github.com/Meteor-Community-Packages/meteor-roles/pull/371) [@copleykj](https://github.com/sponsors/copleykj) From a934d0e5ad3593393195b25973579a5ce0abe53a Mon Sep 17 00:00:00 2001 From: Jan Dvorak Date: Thu, 24 Aug 2023 11:27:05 +0200 Subject: [PATCH 07/45] UI helpers console logs to debugs --- roles/client/uiHelpers.js | 8 ++-- roles/versions.json | 95 --------------------------------------- 2 files changed, 4 insertions(+), 99 deletions(-) delete mode 100644 roles/versions.json diff --git a/roles/client/uiHelpers.js b/roles/client/uiHelpers.js index e73040a8..0414adc3 100644 --- a/roles/client/uiHelpers.js +++ b/roles/client/uiHelpers.js @@ -73,16 +73,16 @@ Roles._uiHelpers = { // Register UI helpers // -if (Roles.debug && console.log) { - console.log('[roles] Roles.debug =', Roles.debug) +if (Roles.debug && console.debug) { + console.debug('[roles] Roles.debug =', Roles.debug) } if (typeof Package.blaze !== 'undefined' && typeof Package.blaze.Blaze !== 'undefined' && typeof Package.blaze.Blaze.registerHelper === 'function') { Object.entries(Roles._uiHelpers).forEach(([name, func]) => { - if (Roles.debug && console.log) { - console.log('[roles] registering Blaze helper \'' + name + '\'') + if (Roles.debug && console.debug) { + console.debug('[roles] registering Blaze helper \'' + name + '\'') } Package.blaze.Blaze.registerHelper(name, func) }) diff --git a/roles/versions.json b/roles/versions.json deleted file mode 100644 index 82627b70..00000000 --- a/roles/versions.json +++ /dev/null @@ -1,95 +0,0 @@ -{ - "dependencies": [ - [ - "accounts-base", - "1.0.0" - ], - [ - "application-configuration", - "1.0.0" - ], - [ - "binary-heap", - "1.0.0" - ], - [ - "callback-hook", - "1.0.0" - ], - [ - "check", - "1.0.0" - ], - [ - "deps", - "1.0.1" - ], - [ - "ejson", - "1.0.0" - ], - [ - "follower-livedata", - "1.0.0" - ], - [ - "geojson-utils", - "1.0.0" - ], - [ - "id-map", - "1.0.0" - ], - [ - "json", - "1.0.0" - ], - [ - "livedata", - "1.0.7" - ], - [ - "localstorage", - "1.0.0" - ], - [ - "logging", - "1.0.2" - ], - [ - "meteor", - "1.0.2" - ], - [ - "minimongo", - "1.0.1" - ], - [ - "mongo-livedata", - "1.0.3" - ], - [ - "ordered-dict", - "1.0.0" - ], - [ - "random", - "1.0.0" - ], - [ - "retry", - "1.0.0" - ], - [ - "service-configuration", - "1.0.0" - ], - [ - "underscore", - "1.0.0" - ] - ], - "pluginDependencies": [], - "toolVersion": "meteor-tool@1.0.16", - "format": "1.0" -} \ No newline at end of file From 2d57e390d9c79a80001d94d1a49b1547d808a924 Mon Sep 17 00:00:00 2001 From: Jan Dvorak Date: Thu, 24 Aug 2023 11:31:45 +0200 Subject: [PATCH 08/45] Prep package.js for v4 --- package.js | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/package.js b/package.js index 632bc374..12c902dd 100644 --- a/package.js +++ b/package.js @@ -2,13 +2,13 @@ Package.describe({ summary: 'Authorization package for Meteor', - version: '3.5.1', + version: '4.0.0-alpha.1', git: 'https://github.com/Meteor-Community-Packages/meteor-roles.git', name: 'alanning:roles' }) Package.onUse(function (api) { - api.versionsFrom(['1.12', '2.3', '2.8.0']) + api.versionsFrom(['2.8.1', '3.0-alpha.11']) const both = ['client', 'server'] @@ -43,7 +43,7 @@ Package.onTest(function (api) { 'meteortesting:mocha@2.1.0' ]) - api.versionsFrom('2.3') + api.versionsFrom('2.8.1') const both = ['client', 'server'] From d9adc1579f077e245d1ac6e3eeb16e7a6ed0460c Mon Sep 17 00:00:00 2001 From: Jan Dvorak Date: Mon, 8 Apr 2024 16:50:15 +0200 Subject: [PATCH 09/45] Export collections --- roles/roles_common_async.js | 8 ++++++-- 1 file changed, 6 insertions(+), 2 deletions(-) diff --git a/roles/roles_common_async.js b/roles/roles_common_async.js index 6ca1a9f6..b6cf119a 100644 --- a/roles/roles_common_async.js +++ b/roles/roles_common_async.js @@ -26,12 +26,16 @@ import { Mongo } from 'meteor/mongo' * * @module Roles */ +export const RolesCollection = new Mongo.Collection('roles') + if (!Meteor.roles) { - Meteor.roles = new Mongo.Collection('roles') + Meteor.roles = RolesCollection } +export const RoleAssignmentCollection = new Mongo.Collection('role-assignment') + if (!Meteor.roleAssignment) { - Meteor.roleAssignment = new Mongo.Collection('role-assignment') + Meteor.roleAssignment = RoleAssignmentCollection } /** From ab55827c64dd6be8cbdda98feddd59e10c35dde3 Mon Sep 17 00:00:00 2001 From: Jan Dvorak Date: Mon, 8 Apr 2024 16:50:32 +0200 Subject: [PATCH 10/45] Sync functions only on client --- History.md | 7 + definitions.d.ts | 5 + package.js | 8 +- roles/{roles_common.js => roles_client.js} | 12 +- roles/roles_server.js | 414 +--- roles/tests/client.js | 2 +- roles/tests/clientAsync.js | 3 +- roles/tests/server.js | 2281 -------------------- roles/tests/serverAsync.js | 3 +- 9 files changed, 26 insertions(+), 2709 deletions(-) rename roles/{roles_common.js => roles_client.js} (99%) delete mode 100644 roles/tests/server.js diff --git a/History.md b/History.md index 2cc8b641..300ea913 100644 --- a/History.md +++ b/History.md @@ -1,5 +1,12 @@ # Changelog +## v4.0.0 + +* BREAKING: Synchronous functions are now available only on client side +* * BREAKING: Migration functions for past versions are no longer available +* UI Helpers now use `console.debug` for debugging messages +* `RolesCollection` and `RoleAssignmentsCollection` can now be exported in addition to being accessed via `Meteor.roles` and `Meteor.roleAssignment` + ## v3.6.2 * Fixed TypeScript definition to play nice with Meteor definition [#389](https://github.com/Meteor-Community-Packages/meteor-roles/pull/389) [@bruceborrett](https://github.com/sponsors/bruceborrett) diff --git a/definitions.d.ts b/definitions.d.ts index f783854c..d8f44410 100644 --- a/definitions.d.ts +++ b/definitions.d.ts @@ -430,6 +430,11 @@ declare namespace Roles { } // module +// Exported collections +declare type RolesCollection = Mongo.Collection +declare type RoleAssignmentsCollection = Mongo.Collection + +// Additions to the Meteor object declare module 'meteor/meteor' { namespace Meteor { const roles: Mongo.Collection diff --git a/package.js b/package.js index bb5e0fbd..498bc075 100644 --- a/package.js +++ b/package.js @@ -8,7 +8,7 @@ Package.describe({ }) Package.onUse(function (api) { - api.versionsFrom(['2.8.1', '3.0-alpha.11']) + api.versionsFrom(['2.8.1', '3.0-beta.7']) const both = ['client', 'server'] @@ -20,13 +20,13 @@ Package.onUse(function (api) { 'check' ], both) - api.use('zodern:types@1.0.11') + api.use('zodern:types@1.0.13') - api.use(['blaze@2.7.1'], 'client', { weak: true }) + api.use(['blaze@2.9.0'], 'client', { weak: true }) api.export('Roles') - api.addFiles('roles/roles_common.js', both) + api.addFiles('roles/roles_client.js', 'client') api.addFiles('roles/roles_common_async.js', both) api.addFiles('roles/roles_server.js', 'server') api.addFiles([ diff --git a/roles/roles_common.js b/roles/roles_client.js similarity index 99% rename from roles/roles_common.js rename to roles/roles_client.js index 3dfcefe3..afb80711 100644 --- a/roles/roles_common.js +++ b/roles/roles_client.js @@ -1,9 +1,10 @@ -/* global Meteor, Roles, Mongo */ +/* global Meteor, Roles */ +import { Meteor } from 'meteor/meteor' /** * Provides functions related to user authorization. Compatible with built-in Meteor accounts packages. * - * Roles are accessible throgh `Meteor.roles` collection and documents consist of: + * Roles are accessible through `Meteor.roles` collection and documents consist of: * - `_id`: role name * - `children`: list of subdocuments: * - `_id` @@ -24,13 +25,6 @@ * * @module Roles */ -if (!Meteor.roles) { - Meteor.roles = new Mongo.Collection('roles') -} - -if (!Meteor.roleAssignment) { - Meteor.roleAssignment = new Mongo.Collection('role-assignment') -} /** * @class Roles diff --git a/roles/roles_server.js b/roles/roles_server.js index fdf03794..ead157fb 100644 --- a/roles/roles_server.js +++ b/roles/roles_server.js @@ -1,17 +1,7 @@ -/* global Meteor, Roles */ -let indexFnAssignment -let indexFnRoles +import { Meteor } from 'meteor/meteor' -if (Meteor.roles.createIndexAsync) { - indexFnAssignment = Meteor.roleAssignment.createIndexAsync.bind(Meteor.roleAssignment) - indexFnRoles = Meteor.roles.createIndexAsync.bind(Meteor.roles) -} else if (Meteor.roles.createIndex) { - indexFnAssignment = Meteor.roleAssignment.createIndex.bind(Meteor.roleAssignment) - indexFnRoles = Meteor.roles.createIndex.bind(Meteor.roles) -} else { - indexFnAssignment = Meteor.roleAssignment._ensureIndex.bind(Meteor.roleAssignment) - indexFnRoles = Meteor.roles._ensureIndex.bind(Meteor.roles) -} +const indexFnAssignment = Meteor.roleAssignment.createIndexAsync.bind(Meteor.roleAssignment) +const indexFnRoles = Meteor.roles.createIndexAsync.bind(Meteor.roles) [ { 'user._id': 1, 'inheritedRoles._id': 1, scope: 1 }, @@ -41,401 +31,3 @@ Meteor.publish('_roles', function () { { fields } ) }) - -Object.assign(Roles, { - /** - * @method _isNewRole - * @param {Object} role `Meteor.roles` document. - * @return {Boolean} Returns `true` if the `role` is in the new format. - * If it is ambiguous or it is not, returns `false`. - * @for Roles - * @private - * @static - */ - _isNewRole: function (role) { - return !('name' in role) && 'children' in role - }, - - /** - * @method _isOldRole - * @param {Object} role `Meteor.roles` document. - * @return {Boolean} Returns `true` if the `role` is in the old format. - * If it is ambiguous or it is not, returns `false`. - * @for Roles - * @private - * @static - */ - _isOldRole: function (role) { - return 'name' in role && !('children' in role) - }, - - /** - * @method _isNewField - * @param {Array} roles `Meteor.users` document `roles` field. - * @return {Boolean} Returns `true` if the `roles` field is in the new format. - * If it is ambiguous or it is not, returns `false`. - * @for Roles - * @private - * @static - */ - _isNewField: function (roles) { - return Array.isArray(roles) && typeof roles[0] === 'object' - }, - - /** - * @method _isOldField - * @param {Array} roles `Meteor.users` document `roles` field. - * @return {Boolean} Returns `true` if the `roles` field is in the old format. - * If it is ambiguous or it is not, returns `false`. - * @for Roles - * @private - * @static - */ - _isOldField: function (roles) { - return ( - (Array.isArray(roles) && typeof roles[0] === 'string') || - (typeof roles === 'object' && !Array.isArray(roles)) - ) - }, - - /** - * @method _convertToNewRole - * @param {Object} oldRole `Meteor.roles` document. - * @return {Object} Converted `role` to the new format. - * @for Roles - * @private - * @static - */ - _convertToNewRole: function (oldRole) { - if (!(typeof oldRole.name === 'string')) { throw new Error("Role name '" + oldRole.name + "' is not a string.") } - - return { - _id: oldRole.name, - children: [] - } - }, - - /** - * @method _convertToOldRole - * @param {Object} newRole `Meteor.roles` document. - * @return {Object} Converted `role` to the old format. - * @for Roles - * @private - * @static - */ - _convertToOldRole: function (newRole) { - if (!(typeof newRole._id === 'string')) { throw new Error("Role name '" + newRole._id + "' is not a string.") } - - return { - name: newRole._id - } - }, - - /** - * @method _convertToNewField - * @param {Array} oldRoles `Meteor.users` document `roles` field in the old format. - * @param {Boolean} convertUnderscoresToDots Should we convert underscores to dots in group names. - * @return {Array} Converted `roles` to the new format. - * @for Roles - * @private - * @static - */ - _convertToNewField: function (oldRoles, convertUnderscoresToDots) { - const roles = [] - if (Array.isArray(oldRoles)) { - oldRoles.forEach(function (role, index) { - if (!(typeof role === 'string')) { throw new Error("Role '" + role + "' is not a string.") } - - roles.push({ - _id: role, - scope: null, - assigned: true - }) - }) - } else if (typeof oldRoles === 'object') { - Object.entries(oldRoles).forEach(([group, rolesArray]) => { - if (group === '__global_roles__') { - group = null - } else if (convertUnderscoresToDots) { - // unescape - group = group.replace(/_/g, '.') - } - - rolesArray.forEach(function (role) { - if (!(typeof role === 'string')) { throw new Error("Role '" + role + "' is not a string.") } - - roles.push({ - _id: role, - scope: group, - assigned: true - }) - }) - }) - } - return roles - }, - - /** - * @method _convertToOldField - * @param {Array} newRoles `Meteor.users` document `roles` field in the new format. - * @param {Boolean} usingGroups Should we use groups or not. - * @return {Array} Converted `roles` to the old format. - * @for Roles - * @private - * @static - */ - _convertToOldField: function (newRoles, usingGroups) { - let roles - - if (usingGroups) { - roles = {} - } else { - roles = [] - } - - newRoles.forEach(function (userRole) { - if (!(typeof userRole === 'object')) { throw new Error("Role '" + userRole + "' is not an object.") } - - // We assume that we are converting back a failed migration, so values can only be - // what were valid values in 1.0. So no group names starting with $ and no subroles. - - if (userRole.scope) { - if (!usingGroups) { - throw new Error( - "Role '" + - userRole._id + - "' with scope '" + - userRole.scope + - "' without enabled groups." - ) - } - - // escape - const scope = userRole.scope.replace(/\./g, '_') - - if (scope[0] === '$') { throw new Error("Group name '" + scope + "' start with $.") } - - roles[scope] = roles[scope] || [] - roles[scope].push(userRole._id) - } else { - if (usingGroups) { - roles.__global_roles__ = roles.__global_roles__ || [] - roles.__global_roles__.push(userRole._id) - } else { - roles.push(userRole._id) - } - } - }) - return roles - }, - - /** - * @method _defaultUpdateUser - * @param {Object} user `Meteor.users` document. - * @param {Array|Object} roles Value to which user's `roles` field should be set. - * @for Roles - * @private - * @static - */ - _defaultUpdateUser: function (user, roles) { - Meteor.users.update( - { - _id: user._id, - // making sure nothing changed in meantime - roles: user.roles - }, - { - $set: { roles } - } - ) - }, - - /** - * @method _defaultUpdateRole - * @param {Object} oldRole Old `Meteor.roles` document. - * @param {Object} newRole New `Meteor.roles` document. - * @for Roles - * @private - * @static - */ - _defaultUpdateRole: function (oldRole, newRole) { - Meteor.roles.remove(oldRole._id) - Meteor.roles.insert(newRole) - }, - - /** - * @method _dropCollectionIndex - * @param {Object} collection Collection on which to drop the index. - * @param {String} indexName Name of the index to drop. - * @for Roles - * @private - * @static - */ - _dropCollectionIndex: function (collection, indexName) { - try { - collection._dropIndex(indexName) - } catch (e) { - const indexNotFound = /index not found/.test(e.message || e.err || e.errmsg) - - if (!indexNotFound) { - throw e - } - } - }, - - /** - * Migrates `Meteor.users` and `Meteor.roles` to the new format. - * - * @method _forwardMigrate - * @param {Function} updateUser Function which updates the user object. Default `_defaultUpdateUser`. - * @param {Function} updateRole Function which updates the role object. Default `_defaultUpdateRole`. - * @param {Boolean} convertUnderscoresToDots Should we convert underscores to dots in group names. - * @for Roles - * @private - * @static - */ - _forwardMigrate: function (updateUser, updateRole, convertUnderscoresToDots) { - updateUser = updateUser || Roles._defaultUpdateUser - updateRole = updateRole || Roles._defaultUpdateRole - - Roles._dropCollectionIndex(Meteor.roles, 'name_1') - - Meteor.roles.find().forEach(function (role, index, cursor) { - if (!Roles._isNewRole(role)) { - updateRole(role, Roles._convertToNewRole(role)) - } - }) - - Meteor.users.find().forEach(function (user, index, cursor) { - if (!Roles._isNewField(user.roles)) { - updateUser( - user, - Roles._convertToNewField(user.roles, convertUnderscoresToDots) - ) - } - }) - }, - - /** - * Moves the assignments from `Meteor.users` to `Meteor.roleAssignment`. - * - * @method _forwardMigrate2 - * @param {Object} userSelector An opportunity to share the work among instances. It's advisable to do the division based on user-id. - * @for Roles - * @private - * @static - */ - _forwardMigrate2: function (userSelector) { - userSelector = userSelector || {} - Object.assign(userSelector, { roles: { $ne: null } }) - - Meteor.users.find(userSelector).forEach(function (user, index) { - user.roles - .filter((r) => r.assigned) - .forEach((r) => { - // Added `ifExists` to make it less error-prone - Roles._addUserToRole(user._id, r._id, { - scope: r.scope, - ifExists: true - }) - }) - - Meteor.users.update({ _id: user._id }, { $unset: { roles: '' } }) - }) - - // No need to keep the indexes around - Roles._dropCollectionIndex(Meteor.users, 'roles._id_1_roles.scope_1') - Roles._dropCollectionIndex(Meteor.users, 'roles.scope_1') - }, - - /** - * Migrates `Meteor.users` and `Meteor.roles` to the old format. - * - * We assume that we are converting back a failed migration, so values can only be - * what were valid values in the old format. So no group names starting with `$` and - * no subroles. - * - * @method _backwardMigrate - * @param {Function} updateUser Function which updates the user object. Default `_defaultUpdateUser`. - * @param {Function} updateRole Function which updates the role object. Default `_defaultUpdateRole`. - * @param {Boolean} usingGroups Should we use groups or not. - * @for Roles - * @private - * @static - */ - _backwardMigrate: function (updateUser, updateRole, usingGroups) { - updateUser = updateUser || Roles._defaultUpdateUser - updateRole = updateRole || Roles._defaultUpdateRole - - Roles._dropCollectionIndex(Meteor.users, 'roles._id_1_roles.scope_1') - Roles._dropCollectionIndex(Meteor.users, 'roles.scope_1') - - Meteor.roles.find().forEach(function (role, index, cursor) { - if (!Roles._isOldRole(role)) { - updateRole(role, Roles._convertToOldRole(role)) - } - }) - - Meteor.users.find().forEach(function (user, index, cursor) { - if (!Roles._isOldField(user.roles)) { - updateUser(user, Roles._convertToOldField(user.roles, usingGroups)) - } - }) - }, - - /** - * Moves the assignments from `Meteor.roleAssignment` back to to `Meteor.users`. - * - * @method _backwardMigrate2 - * @param {Object} assignmentSelector An opportunity to share the work among instances. It's advisable to do the division based on user-id. - * @for Roles - * @private - * @static - */ - _backwardMigrate2: function (assignmentSelector) { - assignmentSelector = assignmentSelector || {} - - if (Meteor.users.createIndex) { - Meteor.users.createIndex({ 'roles._id': 1, 'roles.scope': 1 }) - Meteor.users.createIndex({ 'roles.scope': 1 }) - } else { - Meteor.users._ensureIndex({ 'roles._id': 1, 'roles.scope': 1 }) - Meteor.users._ensureIndex({ 'roles.scope': 1 }) - } - - Meteor.roleAssignment.find(assignmentSelector).forEach((r) => { - const roles = Meteor.users.findOne({ _id: r.user._id }).roles || [] - - const currentRole = roles.find( - (oldRole) => oldRole._id === r.role._id && oldRole.scope === r.scope - ) - if (currentRole) { - currentRole.assigned = true - } else { - roles.push({ - _id: r.role._id, - scope: r.scope, - assigned: true - }) - - r.inheritedRoles.forEach((inheritedRole) => { - const currentInheritedRole = roles.find( - (oldRole) => - oldRole._id === inheritedRole._id && oldRole.scope === r.scope - ) - - if (!currentInheritedRole) { - roles.push({ - _id: inheritedRole._id, - scope: r.scope, - assigned: false - }) - } - }) - } - - Meteor.users.update({ _id: r.user._id }, { $set: { roles } }) - Meteor.roleAssignment.remove({ _id: r._id }) - }) - } -}) diff --git a/roles/tests/client.js b/roles/tests/client.js index 84e8808f..317feebc 100644 --- a/roles/tests/client.js +++ b/roles/tests/client.js @@ -5,7 +5,7 @@ import { Meteor } from 'meteor/meteor' import { assert } from 'chai' // To ensure that the files are loaded for coverage -import '../roles_common' +import '../roles_client' const safeInsert = (collection, data) => { try { diff --git a/roles/tests/clientAsync.js b/roles/tests/clientAsync.js index ce1575e4..4e00c78c 100644 --- a/roles/tests/clientAsync.js +++ b/roles/tests/clientAsync.js @@ -6,7 +6,8 @@ import chai, { assert } from 'chai' import chaiAsPromised from 'chai-as-promised' // To ensure that the files are loaded for coverage -import '../roles_common' +import '../roles_client' +import '../roles_common_async' chai.use(chaiAsPromised) diff --git a/roles/tests/server.js b/roles/tests/server.js deleted file mode 100644 index 5ed65b56..00000000 --- a/roles/tests/server.js +++ /dev/null @@ -1,2281 +0,0 @@ -/* eslint-env mocha */ -/* global Roles */ - -import { Meteor } from 'meteor/meteor' -import { assert } from 'chai' - -// To ensure that the files are loaded for coverage -import '../roles_server' -import '../roles_common' - -// To allow inserting on the client, needed for testing. -Meteor.roleAssignment.allow({ - insert () { return true }, - update () { return true }, - remove () { return true } -}) - -const hasProp = (target, prop) => Object.hasOwnProperty.call(target, prop) - -describe('roles', function () { - let users = {} - const roles = ['admin', 'editor', 'user'] - - Meteor.publish('_roleAssignments', function () { - const loggedInUserId = this.userId - - if (!loggedInUserId) { - this.ready() - return - } - - return Meteor.roleAssignment.find({ _id: loggedInUserId }) - }) - - function addUser (name) { - return Meteor.users.insert({ username: name }) - } - - function testUser (username, expectedRoles, scope) { - const userId = users[username] - const userObj = Meteor.users.findOne({ _id: userId }) - - // check using user ids (makes db calls) - _innerTest(userId, username, expectedRoles, scope) - - // check using passed-in user object - _innerTest(userObj, username, expectedRoles, scope) - } - - function _innerTest (userParam, username, expectedRoles, scope) { - // test that user has only the roles expected and no others - roles.forEach(function (role) { - const expected = expectedRoles.includes(role) - const msg = username + ' expected to have \'' + role + '\' role but does not' - const nmsg = username + ' had the following un-expected role: ' + role - - if (expected) { - assert.isTrue(Roles.userIsInRole(userParam, role, scope), msg) - } else { - assert.isFalse(Roles.userIsInRole(userParam, role, scope), nmsg) - } - }) - } - - beforeEach(function () { - Meteor.roles.remove({}) - Meteor.roleAssignment.remove({}) - Meteor.users.remove({}) - - users = { - eve: addUser('eve'), - bob: addUser('bob'), - joe: addUser('joe') - } - }) - - it('can create and delete roles', function () { - const role1Id = Roles.createRole('test1') - assert.equal(Meteor.roles.findOne()._id, 'test1') - assert.equal(Meteor.roles.findOne(role1Id)._id, 'test1') - - const role2Id = Roles.createRole('test2') - assert.equal(Meteor.roles.findOne({ _id: 'test2' })._id, 'test2') - assert.equal(Meteor.roles.findOne(role2Id)._id, 'test2') - - assert.equal(Meteor.roles.find().count(), 2) - - Roles.deleteRole('test1') - assert.equal(typeof Meteor.roles.findOne({ _id: 'test1' }), 'undefined') - - Roles.deleteRole('test2') - assert.equal(typeof Meteor.roles.findOne(), 'undefined') - }) - - it('can try to remove non-existing roles without crashing', function () { - Roles.deleteRole('non-existing-role') - }) - - it('can\'t create duplicate roles', function () { - Roles.createRole('test1') - assert.throws(function () { Roles.createRole('test1') }) - assert.isNull(Roles.createRole('test1', { unlessExists: true })) - }) - - it('can\'t create role with empty names', function () { - assert.throws(function () { - Roles.createRole('') - }, /Invalid role name/) - assert.throws(function () { - Roles.createRole(null) - }, /Invalid role name/) - assert.throws(function () { - Roles.createRole(' ') - }, /Invalid role name/) - assert.throws(function () { - Roles.createRole(' foobar') - }, /Invalid role name/) - assert.throws(function () { - Roles.createRole(' foobar ') - }, /Invalid role name/) - }) - - it('can\'t use invalid scope names', function () { - Roles.createRole('admin') - Roles.createRole('user') - Roles.createRole('editor') - Roles.addUsersToRoles(users.eve, ['admin', 'user'], 'scope1') - Roles.addUsersToRoles(users.eve, ['editor'], 'scope2') - - assert.throws(function () { - Roles.addUsersToRoles(users.eve, ['admin', 'user'], '') - }, /Invalid scope name/) - assert.throws(function () { - Roles.addUsersToRoles(users.eve, ['admin', 'user'], ' ') - }, /Invalid scope name/) - assert.throws(function () { - Roles.addUsersToRoles(users.eve, ['admin', 'user'], ' foobar') - }, /Invalid scope name/) - assert.throws(function () { - Roles.addUsersToRoles(users.eve, ['admin', 'user'], ' foobar ') - }, /Invalid scope name/) - assert.throws(function () { - Roles.addUsersToRoles(users.eve, ['admin', 'user'], 42) - }, /Invalid scope name/) - }) - - it('can check if user is in role', function () { - Roles.createRole('admin') - Roles.createRole('user') - Roles.addUsersToRoles(users.eve, ['admin', 'user']) - - testUser('eve', ['admin', 'user']) - }) - - it('can check if user is in role by scope', function () { - Roles.createRole('admin') - Roles.createRole('user') - Roles.createRole('editor') - Roles.addUsersToRoles(users.eve, ['admin', 'user'], 'scope1') - Roles.addUsersToRoles(users.eve, ['editor'], 'scope2') - - testUser('eve', ['admin', 'user'], 'scope1') - testUser('eve', ['editor'], 'scope2') - - assert.isFalse(Roles.userIsInRole(users.eve, ['admin', 'user'], 'scope2')) - assert.isFalse(Roles.userIsInRole(users.eve, ['editor'], 'scope1')) - - assert.isTrue(Roles.userIsInRole(users.eve, ['admin', 'user'], { anyScope: true })) - assert.isTrue(Roles.userIsInRole(users.eve, ['editor'], { anyScope: true })) - }) - - it('can check if user is in role by scope through options', function () { - Roles.createRole('admin') - Roles.createRole('user') - Roles.createRole('editor') - Roles.addUsersToRoles(users.eve, ['admin', 'user'], { scope: 'scope1' }) - Roles.addUsersToRoles(users.eve, ['editor'], { scope: 'scope2' }) - - testUser('eve', ['admin', 'user'], { scope: 'scope1' }) - testUser('eve', ['editor'], { scope: 'scope2' }) - }) - - it('can check if user is in role by scope with global role', function () { - Roles.createRole('admin') - Roles.createRole('user') - Roles.createRole('editor') - Roles.addUsersToRoles(users.eve, ['admin', 'user'], 'scope1') - Roles.addUsersToRoles(users.eve, ['editor'], 'scope2') - Roles.addUsersToRoles(users.eve, ['admin']) - - assert.isTrue(Roles.userIsInRole(users.eve, ['user'], 'scope1')) - assert.isTrue(Roles.userIsInRole(users.eve, ['editor'], 'scope2')) - - assert.isFalse(Roles.userIsInRole(users.eve, ['user'])) - assert.isFalse(Roles.userIsInRole(users.eve, ['editor'])) - assert.isFalse(Roles.userIsInRole(users.eve, ['user'], null)) - assert.isFalse(Roles.userIsInRole(users.eve, ['editor'], null)) - - assert.isFalse(Roles.userIsInRole(users.eve, ['user'], 'scope2')) - assert.isFalse(Roles.userIsInRole(users.eve, ['editor'], 'scope1')) - - assert.isTrue(Roles.userIsInRole(users.eve, ['admin'], 'scope2')) - assert.isTrue(Roles.userIsInRole(users.eve, ['admin'], 'scope1')) - assert.isTrue(Roles.userIsInRole(users.eve, ['admin'])) - assert.isTrue(Roles.userIsInRole(users.eve, ['admin'], null)) - }) - - it('renaming scopes', function () { - Roles.createRole('admin') - Roles.createRole('user') - Roles.createRole('editor') - Roles.addUsersToRoles(users.eve, ['admin', 'user'], 'scope1') - Roles.addUsersToRoles(users.eve, ['editor'], 'scope2') - - testUser('eve', ['admin', 'user'], 'scope1') - testUser('eve', ['editor'], 'scope2') - - Roles.renameScope('scope1', 'scope3') - - testUser('eve', ['admin', 'user'], 'scope3') - testUser('eve', ['editor'], 'scope2') - - assert.isFalse(Roles.userIsInRole(users.eve, ['admin', 'user'], 'scope1')) - assert.isFalse(Roles.userIsInRole(users.eve, ['admin', 'user'], 'scope2')) - - assert.throws(function () { - Roles.renameScope('scope3') - }, /Invalid scope name/) - - Roles.renameScope('scope3', null) - - testUser('eve', ['admin', 'user', 'editor'], 'scope2') - - assert.isFalse(Roles.userIsInRole(users.eve, ['editor'])) - assert.isTrue(Roles.userIsInRole(users.eve, ['admin'])) - assert.isTrue(Roles.userIsInRole(users.eve, ['user'])) - assert.isFalse(Roles.userIsInRole(users.eve, ['editor'], null)) - assert.isTrue(Roles.userIsInRole(users.eve, ['admin'], null)) - assert.isTrue(Roles.userIsInRole(users.eve, ['user'], null)) - - Roles.renameScope(null, 'scope2') - - testUser('eve', ['admin', 'user', 'editor'], 'scope2') - - assert.isFalse(Roles.userIsInRole(users.eve, ['editor'])) - assert.isFalse(Roles.userIsInRole(users.eve, ['admin'])) - assert.isFalse(Roles.userIsInRole(users.eve, ['user'])) - assert.isFalse(Roles.userIsInRole(users.eve, ['editor'], null)) - assert.isFalse(Roles.userIsInRole(users.eve, ['admin'], null)) - assert.isFalse(Roles.userIsInRole(users.eve, ['user'], null)) - }) - - it('removing scopes', function () { - Roles.createRole('admin') - Roles.createRole('user') - Roles.createRole('editor') - Roles.addUsersToRoles(users.eve, ['admin', 'user'], 'scope1') - Roles.addUsersToRoles(users.eve, ['editor'], 'scope2') - - testUser('eve', ['admin', 'user'], 'scope1') - testUser('eve', ['editor'], 'scope2') - - Roles.removeScope('scope1') - - testUser('eve', ['editor'], 'scope2') - - assert.isFalse(Roles.userIsInRole(users.eve, ['admin', 'user'], 'scope1')) - assert.isFalse(Roles.userIsInRole(users.eve, ['admin', 'user'], 'scope2')) - }) - - it('can check if non-existant user is in role', function () { - assert.isFalse(Roles.userIsInRole('1', 'admin')) - }) - - it('can check if null user is in role', function () { - assert.isFalse(Roles.userIsInRole(null, 'admin')) - }) - - it('can check user against several roles at once', function () { - Roles.createRole('admin') - Roles.createRole('user') - - Roles.addUsersToRoles(users.eve, ['admin', 'user']) - const user = Meteor.users.findOne({ _id: users.eve }) - - // we can check the non-existing role - assert.isTrue(Roles.userIsInRole(user, ['editor', 'admin'])) - }) - - it('can\'t add non-existent user to role', function () { - Roles.createRole('admin') - - Roles.addUsersToRoles(['1'], ['admin']) - assert.equal(Meteor.users.findOne({ _id: '1' }), undefined) - }) - - it('can\'t add user to non-existent role', function () { - assert.throws(function () { - Roles.addUsersToRoles(users.eve, ['admin']) - }, /Role 'admin' does not exist/) - Roles.addUsersToRoles(users.eve, ['admin'], { ifExists: true }) - }) - - it('can\'t set non-existent user to role', function () { - Roles.createRole('admin') - - Roles.setUserRoles(['1'], ['admin']) - assert.equal(Meteor.users.findOne({ _id: '1' }), undefined) - }) - - it('can\'t set user to non-existent role', function () { - assert.throws(function () { - Roles.setUserRoles(users.eve, ['admin']) - }, /Role 'admin' does not exist/) - Roles.setUserRoles(users.eve, ['admin'], { ifExists: true }) - }) - - it('can add individual users to roles', function () { - Roles.createRole('admin') - Roles.createRole('user') - Roles.createRole('editor') - - Roles.addUsersToRoles(users.eve, ['admin', 'user']) - - testUser('eve', ['admin', 'user']) - testUser('bob', []) - testUser('joe', []) - - Roles.addUsersToRoles(users.joe, ['editor', 'user']) - - testUser('eve', ['admin', 'user']) - testUser('bob', []) - testUser('joe', ['editor', 'user']) - }) - - it('can add individual users to roles by scope', function () { - Roles.createRole('admin') - Roles.createRole('user') - Roles.createRole('editor') - - Roles.addUsersToRoles(users.eve, ['admin', 'user'], 'scope1') - - testUser('eve', ['admin', 'user'], 'scope1') - testUser('bob', [], 'scope1') - testUser('joe', [], 'scope1') - - testUser('eve', [], 'scope2') - testUser('bob', [], 'scope2') - testUser('joe', [], 'scope2') - - Roles.addUsersToRoles(users.joe, ['editor', 'user'], 'scope1') - Roles.addUsersToRoles(users.bob, ['editor', 'user'], 'scope2') - - testUser('eve', ['admin', 'user'], 'scope1') - testUser('bob', [], 'scope1') - testUser('joe', ['editor', 'user'], 'scope1') - - testUser('eve', [], 'scope2') - testUser('bob', ['editor', 'user'], 'scope2') - testUser('joe', [], 'scope2') - }) - - it('can add user to roles via user object', function () { - Roles.createRole('admin') - Roles.createRole('user') - Roles.createRole('editor') - - const eve = Meteor.users.findOne({ _id: users.eve }) - const bob = Meteor.users.findOne({ _id: users.bob }) - - Roles.addUsersToRoles(eve, ['admin', 'user']) - - testUser('eve', ['admin', 'user']) - testUser('bob', []) - testUser('joe', []) - - Roles.addUsersToRoles(bob, ['editor']) - - testUser('eve', ['admin', 'user']) - testUser('bob', ['editor']) - testUser('joe', []) - }) - - it('can add user to roles multiple times', function () { - Roles.createRole('admin') - Roles.createRole('user') - Roles.createRole('editor') - - Roles.addUsersToRoles(users.eve, ['admin', 'user']) - Roles.addUsersToRoles(users.eve, ['admin', 'user']) - - testUser('eve', ['admin', 'user']) - testUser('bob', []) - testUser('joe', []) - - Roles.addUsersToRoles(users.bob, ['admin']) - Roles.addUsersToRoles(users.bob, ['editor']) - - testUser('eve', ['admin', 'user']) - testUser('bob', ['admin', 'editor']) - testUser('joe', []) - }) - - it('can add user to roles multiple times by scope', function () { - Roles.createRole('admin') - Roles.createRole('user') - Roles.createRole('editor') - - Roles.addUsersToRoles(users.eve, ['admin', 'user'], 'scope1') - Roles.addUsersToRoles(users.eve, ['admin', 'user'], 'scope1') - - testUser('eve', ['admin', 'user'], 'scope1') - testUser('bob', [], 'scope1') - testUser('joe', [], 'scope1') - - Roles.addUsersToRoles(users.bob, ['admin'], 'scope1') - Roles.addUsersToRoles(users.bob, ['editor'], 'scope1') - - testUser('eve', ['admin', 'user'], 'scope1') - testUser('bob', ['admin', 'editor'], 'scope1') - testUser('joe', [], 'scope1') - }) - - it('can add multiple users to roles', function () { - Roles.createRole('admin') - Roles.createRole('user') - Roles.createRole('editor') - - Roles.addUsersToRoles([users.eve, users.bob], ['admin', 'user']) - - testUser('eve', ['admin', 'user']) - testUser('bob', ['admin', 'user']) - testUser('joe', []) - - Roles.addUsersToRoles([users.bob, users.joe], ['editor', 'user']) - - testUser('eve', ['admin', 'user']) - testUser('bob', ['admin', 'editor', 'user']) - testUser('joe', ['editor', 'user']) - }) - - it('can add multiple users to roles by scope', function () { - Roles.createRole('admin') - Roles.createRole('user') - Roles.createRole('editor') - - Roles.addUsersToRoles([users.eve, users.bob], ['admin', 'user'], 'scope1') - - testUser('eve', ['admin', 'user'], 'scope1') - testUser('bob', ['admin', 'user'], 'scope1') - testUser('joe', [], 'scope1') - - testUser('eve', [], 'scope2') - testUser('bob', [], 'scope2') - testUser('joe', [], 'scope2') - - Roles.addUsersToRoles([users.bob, users.joe], ['editor', 'user'], 'scope1') - Roles.addUsersToRoles([users.bob, users.joe], ['editor', 'user'], 'scope2') - - testUser('eve', ['admin', 'user'], 'scope1') - testUser('bob', ['admin', 'editor', 'user'], 'scope1') - testUser('joe', ['editor', 'user'], 'scope1') - - testUser('eve', [], 'scope2') - testUser('bob', ['editor', 'user'], 'scope2') - testUser('joe', ['editor', 'user'], 'scope2') - }) - - it('can remove individual users from roles', function () { - Roles.createRole('user') - Roles.createRole('editor') - - // remove user role - one user - Roles.addUsersToRoles([users.eve, users.bob], ['editor', 'user']) - testUser('eve', ['editor', 'user']) - testUser('bob', ['editor', 'user']) - Roles.removeUsersFromRoles(users.eve, ['user']) - testUser('eve', ['editor']) - testUser('bob', ['editor', 'user']) - }) - - it('can remove user from roles multiple times', function () { - Roles.createRole('user') - Roles.createRole('editor') - - // remove user role - one user - Roles.addUsersToRoles([users.eve, users.bob], ['editor', 'user']) - testUser('eve', ['editor', 'user']) - testUser('bob', ['editor', 'user']) - Roles.removeUsersFromRoles(users.eve, ['user']) - testUser('eve', ['editor']) - testUser('bob', ['editor', 'user']) - - // try remove again - Roles.removeUsersFromRoles(users.eve, ['user']) - testUser('eve', ['editor']) - }) - - it('can remove users from roles via user object', function () { - Roles.createRole('user') - Roles.createRole('editor') - - const eve = Meteor.users.findOne({ _id: users.eve }) - const bob = Meteor.users.findOne({ _id: users.bob }) - - // remove user role - one user - Roles.addUsersToRoles([eve, bob], ['editor', 'user']) - testUser('eve', ['editor', 'user']) - testUser('bob', ['editor', 'user']) - Roles.removeUsersFromRoles(eve, ['user']) - testUser('eve', ['editor']) - testUser('bob', ['editor', 'user']) - }) - - it('can remove individual users from roles by scope', function () { - Roles.createRole('admin') - Roles.createRole('user') - Roles.createRole('editor') - - // remove user role - one user - Roles.addUsersToRoles([users.eve, users.bob], ['editor', 'user'], 'scope1') - Roles.addUsersToRoles([users.joe, users.bob], ['admin'], 'scope2') - testUser('eve', ['editor', 'user'], 'scope1') - testUser('bob', ['editor', 'user'], 'scope1') - testUser('joe', [], 'scope1') - testUser('eve', [], 'scope2') - testUser('bob', ['admin'], 'scope2') - testUser('joe', ['admin'], 'scope2') - - Roles.removeUsersFromRoles(users.eve, ['user'], 'scope1') - testUser('eve', ['editor'], 'scope1') - testUser('bob', ['editor', 'user'], 'scope1') - testUser('joe', [], 'scope1') - testUser('eve', [], 'scope2') - testUser('bob', ['admin'], 'scope2') - testUser('joe', ['admin'], 'scope2') - }) - - it('can remove individual users from roles by scope through options', function () { - Roles.createRole('admin') - Roles.createRole('user') - Roles.createRole('editor') - - // remove user role - one user - Roles.addUsersToRoles([users.eve, users.bob], ['editor', 'user'], { scope: 'scope1' }) - Roles.addUsersToRoles([users.joe, users.bob], ['admin'], { scope: 'scope2' }) - testUser('eve', ['editor', 'user'], 'scope1') - testUser('bob', ['editor', 'user'], 'scope1') - testUser('joe', [], 'scope1') - testUser('eve', [], 'scope2') - testUser('bob', ['admin'], 'scope2') - testUser('joe', ['admin'], 'scope2') - - Roles.removeUsersFromRoles(users.eve, ['user'], { scope: 'scope1' }) - testUser('eve', ['editor'], 'scope1') - testUser('bob', ['editor', 'user'], 'scope1') - testUser('joe', [], 'scope1') - testUser('eve', [], 'scope2') - testUser('bob', ['admin'], 'scope2') - testUser('joe', ['admin'], 'scope2') - }) - - it('can remove multiple users from roles', function () { - Roles.createRole('admin') - Roles.createRole('user') - Roles.createRole('editor') - - // remove user role - two users - Roles.addUsersToRoles([users.eve, users.bob], ['editor', 'user']) - testUser('eve', ['editor', 'user']) - testUser('bob', ['editor', 'user']) - - assert.isFalse(Roles.userIsInRole(users.joe, 'admin')) - Roles.addUsersToRoles([users.bob, users.joe], ['admin', 'user']) - testUser('bob', ['admin', 'user', 'editor']) - testUser('joe', ['admin', 'user']) - Roles.removeUsersFromRoles([users.bob, users.joe], ['admin']) - testUser('bob', ['user', 'editor']) - testUser('joe', ['user']) - }) - - it('can remove multiple users from roles by scope', function () { - Roles.createRole('admin') - Roles.createRole('user') - Roles.createRole('editor') - - // remove user role - one user - Roles.addUsersToRoles([users.eve, users.bob], ['editor', 'user'], 'scope1') - Roles.addUsersToRoles([users.joe, users.bob], ['admin'], 'scope2') - testUser('eve', ['editor', 'user'], 'scope1') - testUser('bob', ['editor', 'user'], 'scope1') - testUser('joe', [], 'scope1') - testUser('eve', [], 'scope2') - testUser('bob', ['admin'], 'scope2') - testUser('joe', ['admin'], 'scope2') - - Roles.removeUsersFromRoles([users.eve, users.bob], ['user'], 'scope1') - testUser('eve', ['editor'], 'scope1') - testUser('bob', ['editor'], 'scope1') - testUser('joe', [], 'scope1') - testUser('eve', [], 'scope2') - testUser('bob', ['admin'], 'scope2') - testUser('joe', ['admin'], 'scope2') - - Roles.removeUsersFromRoles([users.joe, users.bob], ['admin'], 'scope2') - testUser('eve', [], 'scope2') - testUser('bob', [], 'scope2') - testUser('joe', [], 'scope2') - }) - - it('can remove multiple users from roles of any scope', function () { - Roles.createRole('admin') - Roles.createRole('user') - Roles.createRole('editor') - - // remove user role - one user - Roles.addUsersToRoles([users.eve, users.bob], ['editor', 'user'], 'scope1') - Roles.addUsersToRoles([users.joe, users.bob], ['user'], 'scope2') - testUser('eve', ['editor', 'user'], 'scope1') - testUser('bob', ['editor', 'user'], 'scope1') - testUser('joe', [], 'scope1') - testUser('eve', [], 'scope2') - testUser('bob', ['user'], 'scope2') - testUser('joe', ['user'], 'scope2') - - Roles.removeUsersFromRoles([users.eve, users.bob], ['user'], { anyScope: true }) - testUser('eve', ['editor'], 'scope1') - testUser('bob', ['editor'], 'scope1') - testUser('joe', [], 'scope1') - testUser('eve', [], 'scope2') - testUser('bob', [], 'scope2') - testUser('joe', ['user'], 'scope2') - }) - - it('can set user roles', function () { - Roles.createRole('admin') - Roles.createRole('user') - Roles.createRole('editor') - - const eve = Meteor.users.findOne({ _id: users.eve }) - const bob = Meteor.users.findOne({ _id: users.bob }) - - Roles.setUserRoles([users.eve, bob], ['editor', 'user']) - testUser('eve', ['editor', 'user']) - testUser('bob', ['editor', 'user']) - testUser('joe', []) - - // use addUsersToRoles add some roles - Roles.addUsersToRoles([bob, users.joe], ['admin']) - testUser('eve', ['editor', 'user']) - testUser('bob', ['admin', 'editor', 'user']) - testUser('joe', ['admin']) - - Roles.setUserRoles([eve, bob], ['user']) - testUser('eve', ['user']) - testUser('bob', ['user']) - testUser('joe', ['admin']) - - Roles.setUserRoles(bob, 'editor') - testUser('eve', ['user']) - testUser('bob', ['editor']) - testUser('joe', ['admin']) - - Roles.setUserRoles([users.joe, users.bob], []) - testUser('eve', ['user']) - testUser('bob', []) - testUser('joe', []) - }) - - it('can set user roles by scope', function () { - Roles.createRole('admin') - Roles.createRole('user') - Roles.createRole('editor') - - const eve = Meteor.users.findOne({ _id: users.eve }) - const bob = Meteor.users.findOne({ _id: users.bob }) - const joe = Meteor.users.findOne({ _id: users.joe }) - - Roles.setUserRoles([users.eve, users.bob], ['editor', 'user'], 'scope1') - Roles.setUserRoles([users.bob, users.joe], ['admin'], 'scope2') - testUser('eve', ['editor', 'user'], 'scope1') - testUser('bob', ['editor', 'user'], 'scope1') - testUser('joe', [], 'scope1') - testUser('eve', [], 'scope2') - testUser('bob', ['admin'], 'scope2') - testUser('joe', ['admin'], 'scope2') - - // use addUsersToRoles add some roles - Roles.addUsersToRoles([users.eve, users.bob], ['admin'], 'scope1') - Roles.addUsersToRoles([users.bob, users.joe], ['editor'], 'scope2') - testUser('eve', ['admin', 'editor', 'user'], 'scope1') - testUser('bob', ['admin', 'editor', 'user'], 'scope1') - testUser('joe', [], 'scope1') - testUser('eve', [], 'scope2') - testUser('bob', ['admin', 'editor'], 'scope2') - testUser('joe', ['admin', 'editor'], 'scope2') - - Roles.setUserRoles([eve, bob], ['user'], 'scope1') - Roles.setUserRoles([eve, joe], ['editor'], 'scope2') - testUser('eve', ['user'], 'scope1') - testUser('bob', ['user'], 'scope1') - testUser('joe', [], 'scope1') - testUser('eve', ['editor'], 'scope2') - testUser('bob', ['admin', 'editor'], 'scope2') - testUser('joe', ['editor'], 'scope2') - - Roles.setUserRoles(bob, 'editor', 'scope1') - testUser('eve', ['user'], 'scope1') - testUser('bob', ['editor'], 'scope1') - testUser('joe', [], 'scope1') - testUser('eve', ['editor'], 'scope2') - testUser('bob', ['admin', 'editor'], 'scope2') - testUser('joe', ['editor'], 'scope2') - - assert.isTrue(Roles.getRolesForUser(users.bob, { anyScope: true, fullObjects: true }).map(r => r.scope).includes('scope1')) - assert.isFalse(Roles.getRolesForUser(users.joe, { anyScope: true, fullObjects: true }).map(r => r.scope).includes('scope1')) - - Roles.setUserRoles([bob, users.joe], [], 'scope1') - testUser('eve', ['user'], 'scope1') - testUser('bob', [], 'scope1') - testUser('joe', [], 'scope1') - testUser('eve', ['editor'], 'scope2') - testUser('bob', ['admin', 'editor'], 'scope2') - testUser('joe', ['editor'], 'scope2') - - // When roles in a given scope are removed, we do not want any dangling database content for that scope. - assert.isFalse(Roles.getRolesForUser(users.bob, { anyScope: true, fullObjects: true }).map(r => r.scope).includes('scope1')) - assert.isFalse(Roles.getRolesForUser(users.joe, { anyScope: true, fullObjects: true }).map(r => r.scope).includes('scope1')) - }) - - it('can set user roles by scope including GLOBAL_SCOPE', function () { - Roles.createRole('admin') - Roles.createRole('editor') - - const eve = Meteor.users.findOne({ _id: users.eve }) - - Roles.addUsersToRoles(eve, 'admin', Roles.GLOBAL_SCOPE) - testUser('eve', ['admin'], 'scope1') - testUser('eve', ['admin']) - - Roles.setUserRoles(eve, 'editor', Roles.GLOBAL_SCOPE) - testUser('eve', ['editor'], 'scope2') - testUser('eve', ['editor']) - }) - - it('can set user roles by scope and anyScope', function () { - Roles.createRole('admin') - Roles.createRole('editor') - - const eve = Meteor.users.findOne({ _id: users.eve }) - - assert.sameDeepMembers(Roles.getRolesForUser(users.eve, { anyScope: true, fullObjects: true }).map(obj => { delete obj._id; return obj }), []) - - Roles.addUsersToRoles(eve, 'admin') - - assert.sameDeepMembers(Roles.getRolesForUser(users.eve, { anyScope: true, fullObjects: true }).map(obj => { delete obj._id; return obj }), [{ - role: { _id: 'admin' }, - scope: null, - user: { _id: users.eve }, - inheritedRoles: [{ _id: 'admin' }] - }]) - - Roles.setUserRoles(eve, 'editor', { anyScope: true, scope: 'scope2' }) - - assert.sameDeepMembers(Roles.getRolesForUser(users.eve, { anyScope: true, fullObjects: true }).map(obj => { delete obj._id; return obj }), [{ - role: { _id: 'editor' }, - scope: 'scope2', - user: { _id: users.eve }, - inheritedRoles: [{ _id: 'editor' }] - }]) - }) - - it('can get all roles', function () { - roles.forEach(function (role) { - Roles.createRole(role) - }) - - // compare roles, sorted alphabetically - const expected = roles - const actual = Roles.getAllRoles().fetch().map(r => r._id) - - assert.sameMembers(actual, expected) - - assert.sameMembers(Roles.getAllRoles({ sort: { _id: -1 } }).fetch().map(r => r._id), expected.reverse()) - }) - - it('get an empty list of roles for an empty user', function () { - assert.sameMembers(Roles.getRolesForUser(undefined), []) - assert.sameMembers(Roles.getRolesForUser(null), []) - assert.sameMembers(Roles.getRolesForUser({}), []) - }) - - it('get an empty list of roles for non-existant user', function () { - assert.sameMembers(Roles.getRolesForUser('1'), []) - assert.sameMembers(Roles.getRolesForUser('1', 'scope1'), []) - }) - - it('can get all roles for user', function () { - Roles.createRole('admin') - Roles.createRole('user') - - const userId = users.eve - let userObj - - // by userId - assert.sameMembers(Roles.getRolesForUser(userId), []) - - // by user object - userObj = Meteor.users.findOne({ _id: userId }) - assert.sameMembers(Roles.getRolesForUser(userObj), []) - - Roles.addUsersToRoles(userId, ['admin', 'user']) - - // by userId - assert.sameMembers(Roles.getRolesForUser(userId), ['admin', 'user']) - - // by user object - userObj = Meteor.users.findOne({ _id: userId }) - assert.sameMembers(Roles.getRolesForUser(userObj), ['admin', 'user']) - - assert.sameDeepMembers(Roles.getRolesForUser(userId, { fullObjects: true }).map(obj => { delete obj._id; return obj }), [{ - role: { _id: 'admin' }, - scope: null, - user: { _id: userId }, - inheritedRoles: [{ _id: 'admin' }] - }, { - role: { _id: 'user' }, - scope: null, - user: { _id: userId }, - inheritedRoles: [{ _id: 'user' }] - }]) - }) - - it('can get all roles for user by scope', function () { - Roles.createRole('admin') - Roles.createRole('user') - - const userId = users.eve - let userObj - - // by userId - assert.sameMembers(Roles.getRolesForUser(userId, 'scope1'), []) - - // by user object - userObj = Meteor.users.findOne({ _id: userId }) - assert.sameMembers(Roles.getRolesForUser(userObj, 'scope1'), []) - - // add roles - Roles.addUsersToRoles(userId, ['admin', 'user'], 'scope1') - Roles.addUsersToRoles(userId, ['admin'], 'scope2') - - // by userId - assert.sameMembers(Roles.getRolesForUser(userId, 'scope1'), ['admin', 'user']) - assert.sameMembers(Roles.getRolesForUser(userId, 'scope2'), ['admin']) - assert.sameMembers(Roles.getRolesForUser(userId), []) - - // by user object - userObj = Meteor.users.findOne({ _id: userId }) - assert.sameMembers(Roles.getRolesForUser(userObj, 'scope1'), ['admin', 'user']) - assert.sameMembers(Roles.getRolesForUser(userObj, 'scope2'), ['admin']) - assert.sameMembers(Roles.getRolesForUser(userObj), []) - - assert.sameDeepMembers(Roles.getRolesForUser(userId, { fullObjects: true, scope: 'scope1' }).map(obj => { delete obj._id; return obj }), [{ - role: { _id: 'admin' }, - scope: 'scope1', - user: { _id: userId }, - inheritedRoles: [{ _id: 'admin' }] - }, { - role: { _id: 'user' }, - scope: 'scope1', - user: { _id: userId }, - inheritedRoles: [{ _id: 'user' }] - }]) - assert.sameDeepMembers(Roles.getRolesForUser(userId, { fullObjects: true, scope: 'scope2' }).map(obj => { delete obj._id; return obj }), [{ - role: { _id: 'admin' }, - scope: 'scope2', - user: { _id: userId }, - inheritedRoles: [{ _id: 'admin' }] - }]) - - assert.sameDeepMembers(Roles.getRolesForUser(userId, { fullObjects: true, anyScope: true }).map(obj => { delete obj._id; return obj }), [{ - role: { _id: 'admin' }, - scope: 'scope1', - user: { _id: userId }, - inheritedRoles: [{ _id: 'admin' }] - }, { - role: { _id: 'user' }, - scope: 'scope1', - user: { _id: userId }, - inheritedRoles: [{ _id: 'user' }] - }, { - role: { _id: 'admin' }, - scope: 'scope2', - user: { _id: userId }, - inheritedRoles: [{ _id: 'admin' }] - }]) - - Roles.createRole('PERMISSION') - Roles.addRolesToParent('PERMISSION', 'user') - - assert.sameDeepMembers(Roles.getRolesForUser(userId, { fullObjects: true, scope: 'scope1' }).map(obj => { delete obj._id; return obj }), [{ - role: { _id: 'admin' }, - scope: 'scope1', - user: { _id: userId }, - inheritedRoles: [{ _id: 'admin' }] - }, { - role: { _id: 'user' }, - scope: 'scope1', - user: { _id: userId }, - inheritedRoles: [{ _id: 'user' }, { _id: 'PERMISSION' }] - }]) - assert.sameDeepMembers(Roles.getRolesForUser(userId, { fullObjects: true, scope: 'scope2' }).map(obj => { delete obj._id; return obj }), [{ - role: { _id: 'admin' }, - scope: 'scope2', - user: { _id: userId }, - inheritedRoles: [{ _id: 'admin' }] - }]) - assert.sameMembers(Roles.getRolesForUser(userId, { scope: 'scope1' }), ['admin', 'user', 'PERMISSION']) - assert.sameMembers(Roles.getRolesForUser(userId, { scope: 'scope2' }), ['admin']) - - assert.sameDeepMembers(Roles.getRolesForUser(userId, { fullObjects: true, anyScope: true }).map(obj => { delete obj._id; return obj }), [{ - role: { _id: 'admin' }, - scope: 'scope1', - user: { _id: userId }, - inheritedRoles: [{ _id: 'admin' }] - }, { - role: { _id: 'user' }, - scope: 'scope1', - user: { _id: userId }, - inheritedRoles: [{ _id: 'user' }, { _id: 'PERMISSION' }] - }, { - role: { _id: 'admin' }, - scope: 'scope2', - user: { _id: userId }, - inheritedRoles: [{ _id: 'admin' }] - }]) - assert.sameMembers(Roles.getRolesForUser(userId, { anyScope: true }), ['admin', 'user', 'PERMISSION']) - - assert.sameDeepMembers(Roles.getRolesForUser(userId, { fullObjects: true, scope: 'scope1', onlyAssigned: true }).map(obj => { delete obj._id; return obj }), [{ - role: { _id: 'admin' }, - scope: 'scope1', - user: { _id: userId }, - inheritedRoles: [{ _id: 'admin' }] - }, { - role: { _id: 'user' }, - scope: 'scope1', - user: { _id: userId }, - inheritedRoles: [{ _id: 'user' }, { _id: 'PERMISSION' }] - }]) - assert.sameDeepMembers(Roles.getRolesForUser(userId, { fullObjects: true, scope: 'scope2', onlyAssigned: true }).map(obj => { delete obj._id; return obj }), [{ - role: { _id: 'admin' }, - scope: 'scope2', - user: { _id: userId }, - inheritedRoles: [{ _id: 'admin' }] - }]) - assert.sameMembers(Roles.getRolesForUser(userId, { scope: 'scope1', onlyAssigned: true }), ['admin', 'user']) - assert.sameMembers(Roles.getRolesForUser(userId, { scope: 'scope2', onlyAssigned: true }), ['admin']) - - assert.sameDeepMembers(Roles.getRolesForUser(userId, { fullObjects: true, anyScope: true, onlyAssigned: true }).map(obj => { delete obj._id; return obj }), [{ - role: { _id: 'admin' }, - scope: 'scope1', - user: { _id: userId }, - inheritedRoles: [{ _id: 'admin' }] - }, { - role: { _id: 'user' }, - scope: 'scope1', - user: { _id: userId }, - inheritedRoles: [{ _id: 'user' }, { _id: 'PERMISSION' }] - }, { - role: { _id: 'admin' }, - scope: 'scope2', - user: { _id: userId }, - inheritedRoles: [{ _id: 'admin' }] - }]) - assert.sameMembers(Roles.getRolesForUser(userId, { anyScope: true, onlyAssigned: true }), ['admin', 'user']) - }) - - it('can get only scoped roles for user', function () { - Roles.createRole('admin') - Roles.createRole('user') - - const userId = users.eve - - // add roles - Roles.addUsersToRoles(userId, ['user'], 'scope1') - Roles.addUsersToRoles(userId, ['admin']) - - Roles.createRole('PERMISSION') - Roles.addRolesToParent('PERMISSION', 'user') - - assert.sameMembers(Roles.getRolesForUser(userId, { onlyScoped: true, scope: 'scope1' }), ['user', 'PERMISSION']) - assert.sameMembers(Roles.getRolesForUser(userId, { onlyScoped: true, onlyAssigned: true, scope: 'scope1' }), ['user']) - assert.sameDeepMembers(Roles.getRolesForUser(userId, { onlyScoped: true, fullObjects: true, scope: 'scope1' }).map(obj => { delete obj._id; return obj }), [{ - role: { _id: 'user' }, - scope: 'scope1', - user: { _id: userId }, - inheritedRoles: [{ _id: 'user' }, { _id: 'PERMISSION' }] - }]) - }) - - it('can get all roles for user by scope with periods in name', function () { - Roles.createRole('admin') - - Roles.addUsersToRoles(users.joe, ['admin'], 'example.k12.va.us') - - assert.sameMembers(Roles.getRolesForUser(users.joe, 'example.k12.va.us'), ['admin']) - }) - - it('can get all roles for user by scope including Roles.GLOBAL_SCOPE', function () { - Roles.createRole('admin') - Roles.createRole('user') - Roles.createRole('editor') - - const userId = users.eve - - Roles.addUsersToRoles([users.eve], ['editor'], Roles.GLOBAL_SCOPE) - Roles.addUsersToRoles([users.eve], ['admin', 'user'], 'scope1') - - // by userId - assert.sameMembers(Roles.getRolesForUser(userId, 'scope1'), ['editor', 'admin', 'user']) - assert.sameMembers(Roles.getRolesForUser(userId), ['editor']) - - // by user object - const userObj = Meteor.users.findOne({ _id: userId }) - assert.sameMembers(Roles.getRolesForUser(userObj, 'scope1'), ['editor', 'admin', 'user']) - assert.sameMembers(Roles.getRolesForUser(userObj), ['editor']) - }) - - it('getRolesForUser should not return null entries if user has no roles for scope', function () { - Roles.createRole('editor') - - const userId = users.eve - let userObj - - // by userId - assert.sameMembers(Roles.getRolesForUser(userId, 'scope1'), []) - assert.sameMembers(Roles.getRolesForUser(userId), []) - - // by user object - userObj = Meteor.users.findOne({ _id: userId }) - assert.sameMembers(Roles.getRolesForUser(userObj, 'scope1'), []) - assert.sameMembers(Roles.getRolesForUser(userObj), []) - - Roles.addUsersToRoles([users.eve], ['editor'], Roles.GLOBAL_SCOPE) - - // by userId - assert.sameMembers(Roles.getRolesForUser(userId, 'scope1'), ['editor']) - assert.sameMembers(Roles.getRolesForUser(userId), ['editor']) - - // by user object - userObj = Meteor.users.findOne({ _id: userId }) - assert.sameMembers(Roles.getRolesForUser(userObj, 'scope1'), ['editor']) - assert.sameMembers(Roles.getRolesForUser(userObj), ['editor']) - }) - - it('getRolesForUser should not fail during a call of addUsersToRoles', function () { - Roles.createRole('editor') - - const userId = users.eve - const promises = [] - const interval = setInterval(() => { - promises.push(Promise.resolve().then(() => { Roles.getRolesForUser(userId) })) - }, 0) - - Roles.addUsersToRoles([users.eve], ['editor'], Roles.GLOBAL_SCOPE) - clearInterval(interval) - - return Promise.all(promises) - }) - - it('returns an empty list of scopes for null as user-id', function () { - assert.sameMembers(Roles.getScopesForUser(undefined), []) - assert.sameMembers(Roles.getScopesForUser(null), []) - assert.sameMembers(Roles.getScopesForUser('foo'), []) - assert.sameMembers(Roles.getScopesForUser({}), []) - assert.sameMembers(Roles.getScopesForUser({ _id: 'foo' }), []) - }) - - it('can get all scopes for user', function () { - Roles.createRole('admin') - Roles.createRole('user') - Roles.createRole('editor') - - const userId = users.eve - - Roles.addUsersToRoles([users.eve], ['editor'], 'scope1') - Roles.addUsersToRoles([users.eve], ['admin', 'user'], 'scope2') - - // by userId - assert.sameMembers(Roles.getScopesForUser(userId), ['scope1', 'scope2']) - - // by user object - const userObj = Meteor.users.findOne({ _id: userId }) - assert.sameMembers(Roles.getScopesForUser(userObj), ['scope1', 'scope2']) - }) - - it('can get all scopes for user by role', function () { - Roles.createRole('admin') - Roles.createRole('user') - Roles.createRole('editor') - - const userId = users.eve - - Roles.addUsersToRoles([users.eve], ['editor'], 'scope1') - Roles.addUsersToRoles([users.eve], ['editor', 'user'], 'scope2') - - // by userId - assert.sameMembers(Roles.getScopesForUser(userId, 'user'), ['scope2']) - assert.sameMembers(Roles.getScopesForUser(userId, 'editor'), ['scope1', 'scope2']) - assert.sameMembers(Roles.getScopesForUser(userId, 'admin'), []) - - // by user object - const userObj = Meteor.users.findOne({ _id: userId }) - assert.sameMembers(Roles.getScopesForUser(userObj, 'user'), ['scope2']) - assert.sameMembers(Roles.getScopesForUser(userObj, 'editor'), ['scope1', 'scope2']) - assert.sameMembers(Roles.getScopesForUser(userObj, 'admin'), []) - }) - - it('getScopesForUser returns [] when not using scopes', function () { - Roles.createRole('user') - Roles.createRole('editor') - - const userId = users.eve - - Roles.addUsersToRoles([users.eve], ['editor', 'user']) - - // by userId - assert.sameMembers(Roles.getScopesForUser(userId), []) - assert.sameMembers(Roles.getScopesForUser(userId, 'editor'), []) - assert.sameMembers(Roles.getScopesForUser(userId, ['editor']), []) - assert.sameMembers(Roles.getScopesForUser(userId, ['editor', 'user']), []) - - // by user object - const userObj = Meteor.users.findOne({ _id: userId }) - assert.sameMembers(Roles.getScopesForUser(userObj), []) - assert.sameMembers(Roles.getScopesForUser(userObj, 'editor'), []) - assert.sameMembers(Roles.getScopesForUser(userObj, ['editor']), []) - assert.sameMembers(Roles.getScopesForUser(userObj, ['editor', 'user']), []) - }) - - it('can get all groups for user by role array', function () { - const userId = users.eve - - Roles.createRole('user') - Roles.createRole('editor') - Roles.createRole('moderator') - Roles.createRole('admin') - - Roles.addUsersToRoles([users.eve], ['editor'], 'group1') - Roles.addUsersToRoles([users.eve], ['editor', 'user'], 'group2') - Roles.addUsersToRoles([users.eve], ['moderator'], 'group3') - - // by userId, one role - assert.sameMembers(Roles.getScopesForUser(userId, ['user']), ['group2']) - assert.sameMembers(Roles.getScopesForUser(userId, ['editor']), ['group1', 'group2']) - assert.sameMembers(Roles.getScopesForUser(userId, ['admin']), []) - - // by userId, multiple roles - assert.sameMembers(Roles.getScopesForUser(userId, ['editor', 'user']), ['group1', 'group2']) - assert.sameMembers(Roles.getScopesForUser(userId, ['editor', 'moderator']), ['group1', 'group2', 'group3']) - assert.sameMembers(Roles.getScopesForUser(userId, ['user', 'moderator']), ['group2', 'group3']) - - // by user object, one role - const userObj = Meteor.users.findOne({ _id: userId }) - assert.sameMembers(Roles.getScopesForUser(userObj, ['user']), ['group2']) - assert.sameMembers(Roles.getScopesForUser(userObj, ['editor']), ['group1', 'group2']) - assert.sameMembers(Roles.getScopesForUser(userObj, ['admin']), []) - - // by user object, multiple roles - assert.sameMembers(Roles.getScopesForUser(userObj, ['editor', 'user']), ['group1', 'group2']) - assert.sameMembers(Roles.getScopesForUser(userObj, ['editor', 'moderator']), ['group1', 'group2', 'group3']) - assert.sameMembers(Roles.getScopesForUser(userObj, ['user', 'moderator']), ['group2', 'group3']) - }) - - it('getting all scopes for user does not include GLOBAL_SCOPE', function () { - Roles.createRole('admin') - Roles.createRole('user') - Roles.createRole('editor') - - const userId = users.eve - - Roles.addUsersToRoles([users.eve], ['editor'], 'scope1') - Roles.addUsersToRoles([users.eve], ['editor', 'user'], 'scope2') - Roles.addUsersToRoles([users.eve], ['editor', 'user', 'admin'], Roles.GLOBAL_SCOPE) - - // by userId - assert.sameMembers(Roles.getScopesForUser(userId, 'user'), ['scope2']) - assert.sameMembers(Roles.getScopesForUser(userId, 'editor'), ['scope1', 'scope2']) - assert.sameMembers(Roles.getScopesForUser(userId, 'admin'), []) - assert.sameMembers(Roles.getScopesForUser(userId, ['user']), ['scope2']) - assert.sameMembers(Roles.getScopesForUser(userId, ['editor']), ['scope1', 'scope2']) - assert.sameMembers(Roles.getScopesForUser(userId, ['admin']), []) - assert.sameMembers(Roles.getScopesForUser(userId, ['user', 'editor', 'admin']), ['scope1', 'scope2']) - - // by user object - const userObj = Meteor.users.findOne({ _id: userId }) - assert.sameMembers(Roles.getScopesForUser(userObj, 'user'), ['scope2']) - assert.sameMembers(Roles.getScopesForUser(userObj, 'editor'), ['scope1', 'scope2']) - assert.sameMembers(Roles.getScopesForUser(userObj, 'admin'), []) - assert.sameMembers(Roles.getScopesForUser(userObj, ['user']), ['scope2']) - assert.sameMembers(Roles.getScopesForUser(userObj, ['editor']), ['scope1', 'scope2']) - assert.sameMembers(Roles.getScopesForUser(userObj, ['admin']), []) - assert.sameMembers(Roles.getScopesForUser(userObj, ['user', 'editor', 'admin']), ['scope1', 'scope2']) - }) - - it('can get all users in role', function () { - Roles.createRole('admin') - Roles.createRole('user') - Roles.createRole('editor') - - Roles.addUsersToRoles([users.eve, users.joe], ['admin', 'user']) - Roles.addUsersToRoles([users.bob, users.joe], ['editor']) - - const expected = [users.eve, users.joe] - const actual = Roles.getUsersInRole('admin').fetch().map(r => r._id) - - assert.sameMembers(actual, expected) - }) - - it('can get all users in role by scope', function () { - Roles.createRole('admin') - Roles.createRole('user') - - Roles.addUsersToRoles([users.eve, users.joe], ['admin', 'user'], 'scope1') - Roles.addUsersToRoles([users.bob, users.joe], ['admin'], 'scope2') - - let expected = [users.eve, users.joe] - let actual = Roles.getUsersInRole('admin', 'scope1').fetch().map(r => r._id) - - assert.sameMembers(actual, expected) - - expected = [users.eve, users.joe] - actual = Roles.getUsersInRole('admin', { scope: 'scope1' }).fetch().map(r => r._id) - assert.sameMembers(actual, expected) - - expected = [users.eve, users.bob, users.joe] - actual = Roles.getUsersInRole('admin', { anyScope: true }).fetch().map(r => r._id) - assert.sameMembers(actual, expected) - - actual = Roles.getUsersInRole('admin').fetch().map(r => r._id) - assert.sameMembers(actual, []) - }) - - it('can get all users in role by scope including Roles.GLOBAL_SCOPE', function () { - Roles.createRole('admin') - Roles.createRole('user') - - Roles.addUsersToRoles([users.eve], ['admin', 'user'], Roles.GLOBAL_SCOPE) - Roles.addUsersToRoles([users.bob, users.joe], ['admin'], 'scope2') - - let expected = [users.eve] - let actual = Roles.getUsersInRole('admin', 'scope1').fetch().map(r => r._id) - - assert.sameMembers(actual, expected) - - expected = [users.eve, users.bob, users.joe] - actual = Roles.getUsersInRole('admin', 'scope2').fetch().map(r => r._id) - - assert.sameMembers(actual, expected) - - expected = [users.eve] - actual = Roles.getUsersInRole('admin').fetch().map(r => r._id) - - assert.sameMembers(actual, expected) - - expected = [users.eve, users.bob, users.joe] - actual = Roles.getUsersInRole('admin', { anyScope: true }).fetch().map(r => r._id) - - assert.sameMembers(actual, expected) - }) - - it('can get all users in role by scope excluding Roles.GLOBAL_SCOPE', function () { - Roles.createRole('admin') - - Roles.addUsersToRoles([users.eve], ['admin'], Roles.GLOBAL_SCOPE) - Roles.addUsersToRoles([users.bob], ['admin'], 'scope1') - - let expected = [users.eve] - let actual = Roles.getUsersInRole('admin').fetch().map(r => r._id) - assert.sameMembers(actual, expected) - - expected = [users.eve, users.bob] - actual = Roles.getUsersInRole('admin', { scope: 'scope1' }).fetch().map(r => r._id) - assert.sameMembers(actual, expected) - - expected = [users.bob] - actual = Roles.getUsersInRole('admin', { scope: 'scope1', onlyScoped: true }).fetch().map(r => r._id) - assert.sameMembers(actual, expected) - }) - - it('can get all users in role by scope and passes through mongo query arguments', function () { - Roles.createRole('admin') - Roles.createRole('user') - - Roles.addUsersToRoles([users.eve, users.joe], ['admin', 'user'], 'scope1') - Roles.addUsersToRoles([users.bob, users.joe], ['admin'], 'scope2') - - const results = Roles.getUsersInRole('admin', 'scope1', { fields: { username: 0 }, limit: 1 }).fetch() - - assert.equal(1, results.length) - assert.isTrue(hasProp(results[0], '_id')) - assert.isFalse(hasProp(results[0], 'username')) - }) - - it('can use Roles.GLOBAL_SCOPE to assign blanket roles', function () { - Roles.createRole('admin') - - Roles.addUsersToRoles([users.joe, users.bob], ['admin'], Roles.GLOBAL_SCOPE) - - testUser('eve', [], 'scope1') - testUser('joe', ['admin'], 'scope2') - testUser('joe', ['admin'], 'scope1') - testUser('bob', ['admin'], 'scope2') - testUser('bob', ['admin'], 'scope1') - - Roles.removeUsersFromRoles(users.joe, ['admin'], Roles.GLOBAL_SCOPE) - - testUser('eve', [], 'scope1') - testUser('joe', [], 'scope2') - testUser('joe', [], 'scope1') - testUser('bob', ['admin'], 'scope2') - testUser('bob', ['admin'], 'scope1') - }) - - it('Roles.GLOBAL_SCOPE is independent of other scopes', function () { - Roles.createRole('admin') - - Roles.addUsersToRoles([users.joe, users.bob], ['admin'], 'scope5') - Roles.addUsersToRoles([users.joe, users.bob], ['admin'], Roles.GLOBAL_SCOPE) - - testUser('eve', [], 'scope1') - testUser('joe', ['admin'], 'scope5') - testUser('joe', ['admin'], 'scope2') - testUser('joe', ['admin'], 'scope1') - testUser('bob', ['admin'], 'scope5') - testUser('bob', ['admin'], 'scope2') - testUser('bob', ['admin'], 'scope1') - - Roles.removeUsersFromRoles(users.joe, ['admin'], Roles.GLOBAL_SCOPE) - - testUser('eve', [], 'scope1') - testUser('joe', ['admin'], 'scope5') - testUser('joe', [], 'scope2') - testUser('joe', [], 'scope1') - testUser('bob', ['admin'], 'scope5') - testUser('bob', ['admin'], 'scope2') - testUser('bob', ['admin'], 'scope1') - }) - - it('Roles.GLOBAL_SCOPE also checked when scope not specified', function () { - Roles.createRole('admin') - - Roles.addUsersToRoles(users.joe, 'admin', Roles.GLOBAL_SCOPE) - - testUser('joe', ['admin']) - - Roles.removeUsersFromRoles(users.joe, 'admin', Roles.GLOBAL_SCOPE) - - testUser('joe', []) - }) - - it('can use \'.\' in scope name', function () { - Roles.createRole('admin') - - Roles.addUsersToRoles(users.joe, ['admin'], 'example.com') - testUser('joe', ['admin'], 'example.com') - }) - - it('can use multiple periods in scope name', function () { - Roles.createRole('admin') - - Roles.addUsersToRoles(users.joe, ['admin'], 'example.k12.va.us') - testUser('joe', ['admin'], 'example.k12.va.us') - }) - - it('renaming of roles', function () { - Roles.createRole('admin') - Roles.createRole('user') - Roles.createRole('editor') - - Roles.setUserRoles([users.eve, users.bob], ['editor', 'user'], 'scope1') - Roles.setUserRoles([users.bob, users.joe], ['user', 'admin'], 'scope2') - - assert.isTrue(Roles.userIsInRole(users.eve, 'editor', 'scope1')) - assert.isFalse(Roles.userIsInRole(users.eve, 'editor', 'scope2')) - - assert.isFalse(Roles.userIsInRole(users.joe, 'admin', 'scope1')) - assert.isTrue(Roles.userIsInRole(users.joe, 'admin', 'scope2')) - - assert.isTrue(Roles.userIsInRole(users.eve, 'user', 'scope1')) - assert.isTrue(Roles.userIsInRole(users.bob, 'user', 'scope1')) - assert.isFalse(Roles.userIsInRole(users.joe, 'user', 'scope1')) - - assert.isFalse(Roles.userIsInRole(users.eve, 'user', 'scope2')) - assert.isTrue(Roles.userIsInRole(users.bob, 'user', 'scope2')) - assert.isTrue(Roles.userIsInRole(users.joe, 'user', 'scope2')) - - assert.isFalse(Roles.userIsInRole(users.eve, 'user2', 'scope1')) - assert.isFalse(Roles.userIsInRole(users.eve, 'user2', 'scope2')) - - Roles.renameRole('user', 'user2') - - assert.isTrue(Roles.userIsInRole(users.eve, 'editor', 'scope1')) - assert.isFalse(Roles.userIsInRole(users.eve, 'editor', 'scope2')) - - assert.isFalse(Roles.userIsInRole(users.joe, 'admin', 'scope1')) - assert.isTrue(Roles.userIsInRole(users.joe, 'admin', 'scope2')) - - assert.isTrue(Roles.userIsInRole(users.eve, 'user2', 'scope1')) - assert.isTrue(Roles.userIsInRole(users.bob, 'user2', 'scope1')) - assert.isFalse(Roles.userIsInRole(users.joe, 'user2', 'scope1')) - - assert.isFalse(Roles.userIsInRole(users.eve, 'user2', 'scope2')) - assert.isTrue(Roles.userIsInRole(users.bob, 'user2', 'scope2')) - assert.isTrue(Roles.userIsInRole(users.joe, 'user2', 'scope2')) - - assert.isFalse(Roles.userIsInRole(users.eve, 'user', 'scope1')) - assert.isFalse(Roles.userIsInRole(users.eve, 'user', 'scope2')) - }) - - describe('v2 migration', function () { - it('migration without global groups (to v2)', function () { - assert.isOk(Meteor.roles.insert({ name: 'admin' })) - assert.isOk(Meteor.roles.insert({ name: 'editor' })) - assert.isOk(Meteor.roles.insert({ name: 'user' })) - - assert.isOk(Meteor.users.update(users.eve, { $set: { roles: ['admin', 'editor'] } })) - assert.isOk(Meteor.users.update(users.bob, { $set: { roles: [] } })) - assert.isOk(Meteor.users.update(users.joe, { $set: { roles: ['user'] } })) - - Roles._forwardMigrate() - - assert.deepEqual(Meteor.users.findOne(users.eve, { fields: { roles: 1, _id: 0 } }), { - roles: [{ - _id: 'admin', - scope: null, - assigned: true - }, { - _id: 'editor', - scope: null, - assigned: true - }] - }) - assert.deepEqual(Meteor.users.findOne(users.bob, { fields: { roles: 1, _id: 0 } }), { - roles: [] - }) - assert.deepEqual(Meteor.users.findOne(users.joe, { fields: { roles: 1, _id: 0 } }), { - roles: [{ - _id: 'user', - scope: null, - assigned: true - }] - }) - - assert.deepEqual(Meteor.roles.findOne({ _id: 'admin' }), { - _id: 'admin', - children: [] - }) - assert.deepEqual(Meteor.roles.findOne({ _id: 'editor' }), { - _id: 'editor', - children: [] - }) - assert.deepEqual(Meteor.roles.findOne({ _id: 'user' }), { - _id: 'user', - children: [] - }) - - Roles._backwardMigrate(null, null, false) - - assert.deepEqual(Meteor.users.findOne(users.eve, { fields: { roles: 1, _id: 0 } }), { - roles: ['admin', 'editor'] - }) - assert.deepEqual(Meteor.users.findOne(users.bob, { fields: { roles: 1, _id: 0 } }), { - roles: [] - }) - assert.deepEqual(Meteor.users.findOne(users.joe, { fields: { roles: 1, _id: 0 } }), { - roles: ['user'] - }) - - assert.deepEqual(Meteor.roles.findOne({ name: 'admin' }, { fields: { _id: 0 } }), { - name: 'admin' - }) - assert.deepEqual(Meteor.roles.findOne({ name: 'editor' }, { fields: { _id: 0 } }), { - name: 'editor' - }) - assert.deepEqual(Meteor.roles.findOne({ name: 'user' }, { fields: { _id: 0 } }), { - name: 'user' - }) - }) - - it('migration with global groups (to v2)', function () { - assert.isOk(Meteor.roles.insert({ name: 'admin' })) - assert.isOk(Meteor.roles.insert({ name: 'editor' })) - assert.isOk(Meteor.roles.insert({ name: 'user' })) - - assert.isOk(Meteor.users.update(users.eve, { $set: { roles: { __global_roles__: ['admin', 'editor'], foo_bla: ['user'] } } })) - assert.isOk(Meteor.users.update(users.bob, { $set: { roles: { } } })) - assert.isOk(Meteor.users.update(users.joe, { $set: { roles: { __global_roles__: ['user'], foo_bla: ['user'] } } })) - - Roles._forwardMigrate(null, null, false) - - assert.deepEqual(Meteor.users.findOne(users.eve, { fields: { roles: 1, _id: 0 } }), { - roles: [{ - _id: 'admin', - scope: null, - assigned: true - }, { - _id: 'editor', - scope: null, - assigned: true - }, { - _id: 'user', - scope: 'foo_bla', - assigned: true - }] - }) - assert.deepEqual(Meteor.users.findOne(users.bob, { fields: { roles: 1, _id: 0 } }), { - roles: [] - }) - assert.deepEqual(Meteor.users.findOne(users.joe, { fields: { roles: 1, _id: 0 } }), { - roles: [{ - _id: 'user', - scope: null, - assigned: true - }, { - _id: 'user', - scope: 'foo_bla', - assigned: true - }] - }) - - assert.deepEqual(Meteor.roles.findOne({ _id: 'admin' }), { - _id: 'admin', - children: [] - }) - assert.deepEqual(Meteor.roles.findOne({ _id: 'editor' }), { - _id: 'editor', - children: [] - }) - assert.deepEqual(Meteor.roles.findOne({ _id: 'user' }), { - _id: 'user', - children: [] - }) - - Roles._backwardMigrate(null, null, true) - - assert.deepEqual(Meteor.users.findOne(users.eve, { fields: { roles: 1, _id: 0 } }), { - roles: { - __global_roles__: ['admin', 'editor'], - foo_bla: ['user'] - } - }) - assert.deepEqual(Meteor.users.findOne(users.bob, { fields: { roles: 1, _id: 0 } }), { - roles: {} - }) - assert.deepEqual(Meteor.users.findOne(users.joe, { fields: { roles: 1, _id: 0 } }), { - roles: { - __global_roles__: ['user'], - foo_bla: ['user'] - } - }) - - assert.deepEqual(Meteor.roles.findOne({ name: 'admin' }, { fields: { _id: 0 } }), { - name: 'admin' - }) - assert.deepEqual(Meteor.roles.findOne({ name: 'editor' }, { fields: { _id: 0 } }), { - name: 'editor' - }) - assert.deepEqual(Meteor.roles.findOne({ name: 'user' }, { fields: { _id: 0 } }), { - name: 'user' - }) - - Roles._forwardMigrate(null, null, true) - - assert.deepEqual(Meteor.users.findOne(users.eve, { fields: { roles: 1, _id: 0 } }), { - roles: [{ - _id: 'admin', - scope: null, - assigned: true - }, { - _id: 'editor', - scope: null, - assigned: true - }, { - _id: 'user', - scope: 'foo.bla', - assigned: true - }] - }) - assert.deepEqual(Meteor.users.findOne(users.bob, { fields: { roles: 1, _id: 0 } }), { - roles: [] - }) - assert.deepEqual(Meteor.users.findOne(users.joe, { fields: { roles: 1, _id: 0 } }), { - roles: [{ - _id: 'user', - scope: null, - assigned: true - }, { - _id: 'user', - scope: 'foo.bla', - assigned: true - }] - }) - - assert.deepEqual(Meteor.roles.findOne({ _id: 'admin' }), { - _id: 'admin', - children: [] - }) - assert.deepEqual(Meteor.roles.findOne({ _id: 'editor' }), { - _id: 'editor', - children: [] - }) - assert.deepEqual(Meteor.roles.findOne({ _id: 'user' }), { - _id: 'user', - children: [] - }) - }) - }) - - describe('v3 migration', function () { - it('migration without global groups (to v3)') - - it('migration with global groups (to v3)') - }) - - it('_addUserToRole', function () { - Roles.createRole('admin') - - assert.sameDeepMembers(Roles.getRolesForUser(users.eve, { anyScope: true, fullObjects: true }).map(obj => { delete obj._id; return obj }), []) - - assert.include( - Object.keys(Roles._addUserToRole(users.eve, 'admin', { scope: null, ifExists: false })), - 'insertedId' - ) - - assert.sameDeepMembers(Roles.getRolesForUser(users.eve, { anyScope: true, fullObjects: true }).map(obj => { delete obj._id; return obj }), [{ - role: { _id: 'admin' }, - scope: null, - user: { _id: users.eve }, - inheritedRoles: [{ _id: 'admin' }] - }]) - - assert.notInclude( - Object.keys(Roles._addUserToRole(users.eve, 'admin', { scope: null, ifExists: false })), - 'insertedId' - ) - - assert.sameDeepMembers(Roles.getRolesForUser(users.eve, { anyScope: true, fullObjects: true }).map(obj => { delete obj._id; return obj }), [{ - role: { _id: 'admin' }, - scope: null, - user: { _id: users.eve }, - inheritedRoles: [{ _id: 'admin' }] - }]) - }) - - it('_removeUserFromRole', function () { - Roles.createRole('admin') - - Roles.addUsersToRoles(users.eve, 'admin') - - assert.sameDeepMembers(Roles.getRolesForUser(users.eve, { anyScope: true, fullObjects: true }).map(obj => { delete obj._id; return obj }), [{ - role: { _id: 'admin' }, - scope: null, - user: { _id: users.eve }, - inheritedRoles: [{ _id: 'admin' }] - }]) - - Roles._removeUserFromRole(users.eve, 'admin', { scope: null }) - - assert.sameDeepMembers(Roles.getRolesForUser(users.eve, { anyScope: true, fullObjects: true }).map(obj => { delete obj._id; return obj }), []) - }) - - it('keep assigned roles', function () { - Roles.createRole('admin') - Roles.createRole('user') - Roles.createRole('ALL_PERMISSIONS') - Roles.createRole('VIEW_PERMISSION') - Roles.createRole('EDIT_PERMISSION') - Roles.createRole('DELETE_PERMISSION') - Roles.addRolesToParent('ALL_PERMISSIONS', 'user') - Roles.addRolesToParent('EDIT_PERMISSION', 'ALL_PERMISSIONS') - Roles.addRolesToParent('VIEW_PERMISSION', 'ALL_PERMISSIONS') - Roles.addRolesToParent('DELETE_PERMISSION', 'admin') - - Roles.addUsersToRoles(users.eve, ['user']) - - assert.isTrue(Roles.userIsInRole(users.eve, 'VIEW_PERMISSION')) - - assert.sameDeepMembers(Roles.getRolesForUser(users.eve, { anyScope: true, fullObjects: true }).map(obj => { delete obj._id; return obj }), [{ - role: { _id: 'user' }, - scope: null, - user: { _id: users.eve }, - inheritedRoles: [ - { _id: 'user' }, - { _id: 'ALL_PERMISSIONS' }, - { _id: 'EDIT_PERMISSION' }, - { _id: 'VIEW_PERMISSION' } - ] - }]) - - Roles.addUsersToRoles(users.eve, 'VIEW_PERMISSION') - - assert.isTrue(Roles.userIsInRole(users.eve, 'VIEW_PERMISSION')) - - assert.sameDeepMembers(Roles.getRolesForUser(users.eve, { anyScope: true, fullObjects: true }).map(obj => { delete obj._id; return obj }), [{ - role: { _id: 'user' }, - scope: null, - user: { _id: users.eve }, - inheritedRoles: [ - { _id: 'user' }, - { _id: 'ALL_PERMISSIONS' }, - { _id: 'EDIT_PERMISSION' }, - { _id: 'VIEW_PERMISSION' } - ] - }, { - role: { _id: 'VIEW_PERMISSION' }, - scope: null, - user: { _id: users.eve }, - inheritedRoles: [ - { _id: 'VIEW_PERMISSION' } - ] - }]) - - Roles.removeUsersFromRoles(users.eve, 'user') - - assert.isTrue(Roles.userIsInRole(users.eve, 'VIEW_PERMISSION')) - - assert.sameDeepMembers(Roles.getRolesForUser(users.eve, { anyScope: true, fullObjects: true }).map(obj => { delete obj._id; return obj }), [{ - role: { _id: 'VIEW_PERMISSION' }, - scope: null, - user: { _id: users.eve }, - inheritedRoles: [ - { _id: 'VIEW_PERMISSION' } - ] - }]) - - Roles.removeUsersFromRoles(users.eve, 'VIEW_PERMISSION') - - assert.isFalse(Roles.userIsInRole(users.eve, 'VIEW_PERMISSION')) - - assert.sameDeepMembers(Roles.getRolesForUser(users.eve, { anyScope: true, fullObjects: true }).map(obj => { delete obj._id; return obj }), []) - }) - - it('adds children of the added role to the assignments', function () { - Roles.createRole('admin') - Roles.createRole('ALBUM.ADMIN') - Roles.createRole('ALBUM.VIEW') - Roles.createRole('TRACK.ADMIN') - Roles.createRole('TRACK.VIEW') - - Roles.addRolesToParent('ALBUM.VIEW', 'ALBUM.ADMIN') - Roles.addRolesToParent('TRACK.VIEW', 'TRACK.ADMIN') - - Roles.addRolesToParent('ALBUM.ADMIN', 'admin') - - Roles.addUsersToRoles(users.eve, ['admin']) - - assert.isFalse(Roles.userIsInRole(users.eve, 'TRACK.VIEW')) - - Roles.addRolesToParent('TRACK.ADMIN', 'admin') - - assert.isTrue(Roles.userIsInRole(users.eve, 'TRACK.VIEW')) - }) - - it('removes children of the removed role from the assignments', function () { - Roles.createRole('admin') - Roles.createRole('ALBUM.ADMIN') - Roles.createRole('ALBUM.VIEW') - Roles.createRole('TRACK.ADMIN') - Roles.createRole('TRACK.VIEW') - - Roles.addRolesToParent('ALBUM.VIEW', 'ALBUM.ADMIN') - Roles.addRolesToParent('TRACK.VIEW', 'TRACK.ADMIN') - - Roles.addRolesToParent('ALBUM.ADMIN', 'admin') - Roles.addRolesToParent('TRACK.ADMIN', 'admin') - - Roles.addUsersToRoles(users.eve, ['admin']) - - assert.isTrue(Roles.userIsInRole(users.eve, 'TRACK.VIEW')) - - Roles.removeRolesFromParent('TRACK.ADMIN', 'admin') - - assert.isFalse(Roles.userIsInRole(users.eve, 'TRACK.VIEW')) - }) - - it('modify assigned hierarchical roles', function () { - Roles.createRole('admin') - Roles.createRole('user') - Roles.createRole('ALL_PERMISSIONS') - Roles.createRole('VIEW_PERMISSION') - Roles.createRole('EDIT_PERMISSION') - Roles.createRole('DELETE_PERMISSION') - Roles.addRolesToParent('ALL_PERMISSIONS', 'user') - Roles.addRolesToParent('EDIT_PERMISSION', 'ALL_PERMISSIONS') - Roles.addRolesToParent('VIEW_PERMISSION', 'ALL_PERMISSIONS') - Roles.addRolesToParent('DELETE_PERMISSION', 'admin') - - Roles.addUsersToRoles(users.eve, ['user']) - Roles.addUsersToRoles(users.eve, ['ALL_PERMISSIONS'], 'scope') - - assert.isFalse(Roles.userIsInRole(users.eve, 'MODERATE_PERMISSION')) - assert.isFalse(Roles.userIsInRole(users.eve, 'MODERATE_PERMISSION', 'scope')) - - assert.sameDeepMembers(Roles.getRolesForUser(users.eve, { anyScope: true, fullObjects: true }).map(obj => { delete obj._id; return obj }), [{ - role: { _id: 'user' }, - scope: null, - user: { _id: users.eve }, - inheritedRoles: [ - { _id: 'user' }, - { _id: 'ALL_PERMISSIONS' }, - { _id: 'EDIT_PERMISSION' }, - { _id: 'VIEW_PERMISSION' } - ] - }, { - role: { _id: 'ALL_PERMISSIONS' }, - scope: 'scope', - user: { _id: users.eve }, - inheritedRoles: [ - { _id: 'ALL_PERMISSIONS' }, - { _id: 'EDIT_PERMISSION' }, - { _id: 'VIEW_PERMISSION' } - ] - }]) - - Roles.createRole('MODERATE_PERMISSION') - - Roles.addRolesToParent('MODERATE_PERMISSION', 'ALL_PERMISSIONS') - - assert.isTrue(Roles.userIsInRole(users.eve, 'MODERATE_PERMISSION')) - assert.isTrue(Roles.userIsInRole(users.eve, 'MODERATE_PERMISSION', 'scope')) - - assert.sameDeepMembers(Roles.getRolesForUser(users.eve, { anyScope: true, fullObjects: true }).map(obj => { delete obj._id; return obj }), [{ - role: { _id: 'user' }, - scope: null, - user: { _id: users.eve }, - inheritedRoles: [ - { _id: 'user' }, - { _id: 'ALL_PERMISSIONS' }, - { _id: 'EDIT_PERMISSION' }, - { _id: 'VIEW_PERMISSION' }, - { _id: 'MODERATE_PERMISSION' } - ] - }, { - role: { _id: 'ALL_PERMISSIONS' }, - scope: 'scope', - user: { _id: users.eve }, - inheritedRoles: [ - { _id: 'ALL_PERMISSIONS' }, - { _id: 'EDIT_PERMISSION' }, - { _id: 'VIEW_PERMISSION' }, - { _id: 'MODERATE_PERMISSION' } - ] - }]) - - Roles.addUsersToRoles(users.eve, ['admin']) - - assert.isTrue(Roles.userIsInRole(users.eve, 'DELETE_PERMISSION')) - assert.isTrue(Roles.userIsInRole(users.eve, 'DELETE_PERMISSION', 'scope')) - - assert.sameDeepMembers(Roles.getRolesForUser(users.eve, { anyScope: true, fullObjects: true }).map(obj => { delete obj._id; return obj }), [{ - role: { _id: 'user' }, - scope: null, - user: { _id: users.eve }, - inheritedRoles: [ - { _id: 'user' }, - { _id: 'ALL_PERMISSIONS' }, - { _id: 'EDIT_PERMISSION' }, - { _id: 'VIEW_PERMISSION' }, - { _id: 'MODERATE_PERMISSION' } - ] - }, { - role: { _id: 'ALL_PERMISSIONS' }, - scope: 'scope', - user: { _id: users.eve }, - inheritedRoles: [ - { _id: 'ALL_PERMISSIONS' }, - { _id: 'EDIT_PERMISSION' }, - { _id: 'VIEW_PERMISSION' }, - { _id: 'MODERATE_PERMISSION' } - ] - }, { - role: { _id: 'admin' }, - scope: null, - user: { _id: users.eve }, - inheritedRoles: [ - { _id: 'admin' }, - { _id: 'DELETE_PERMISSION' } - ] - }]) - - Roles.addRolesToParent('DELETE_PERMISSION', 'ALL_PERMISSIONS') - - assert.isTrue(Roles.userIsInRole(users.eve, 'DELETE_PERMISSION')) - assert.isTrue(Roles.userIsInRole(users.eve, 'DELETE_PERMISSION', 'scope')) - - assert.sameDeepMembers(Roles.getRolesForUser(users.eve, { anyScope: true, fullObjects: true }).map(obj => { delete obj._id; return obj }), [{ - role: { _id: 'user' }, - scope: null, - user: { _id: users.eve }, - inheritedRoles: [ - { _id: 'user' }, - { _id: 'ALL_PERMISSIONS' }, - { _id: 'EDIT_PERMISSION' }, - { _id: 'VIEW_PERMISSION' }, - { _id: 'MODERATE_PERMISSION' }, - { _id: 'DELETE_PERMISSION' } - ] - }, { - role: { _id: 'ALL_PERMISSIONS' }, - scope: 'scope', - user: { _id: users.eve }, - inheritedRoles: [ - { _id: 'ALL_PERMISSIONS' }, - { _id: 'EDIT_PERMISSION' }, - { _id: 'VIEW_PERMISSION' }, - { _id: 'MODERATE_PERMISSION' }, - { _id: 'DELETE_PERMISSION' } - ] - }, { - role: { _id: 'admin' }, - scope: null, - user: { _id: users.eve }, - inheritedRoles: [ - { _id: 'admin' }, - { _id: 'DELETE_PERMISSION' } - ] - }]) - - Roles.removeUsersFromRoles(users.eve, ['admin']) - - assert.isTrue(Roles.userIsInRole(users.eve, 'DELETE_PERMISSION')) - assert.isTrue(Roles.userIsInRole(users.eve, 'DELETE_PERMISSION', 'scope')) - - assert.sameDeepMembers(Roles.getRolesForUser(users.eve, { anyScope: true, fullObjects: true }).map(obj => { delete obj._id; return obj }), [{ - role: { _id: 'user' }, - scope: null, - user: { _id: users.eve }, - inheritedRoles: [ - { _id: 'user' }, - { _id: 'ALL_PERMISSIONS' }, - { _id: 'EDIT_PERMISSION' }, - { _id: 'VIEW_PERMISSION' }, - { _id: 'MODERATE_PERMISSION' }, - { _id: 'DELETE_PERMISSION' } - ] - }, { - role: { _id: 'ALL_PERMISSIONS' }, - scope: 'scope', - user: { _id: users.eve }, - inheritedRoles: [ - { _id: 'ALL_PERMISSIONS' }, - { _id: 'EDIT_PERMISSION' }, - { _id: 'VIEW_PERMISSION' }, - { _id: 'MODERATE_PERMISSION' }, - { _id: 'DELETE_PERMISSION' } - ] - }]) - - Roles.deleteRole('ALL_PERMISSIONS') - - assert.isFalse(Roles.userIsInRole(users.eve, 'DELETE_PERMISSION')) - assert.isFalse(Roles.userIsInRole(users.eve, 'DELETE_PERMISSION', 'scope')) - - assert.isFalse(Roles.userIsInRole(users.eve, 'MODERATE_PERMISSION')) - assert.isFalse(Roles.userIsInRole(users.eve, 'MODERATE_PERMISSION', 'scope')) - - assert.sameDeepMembers(Roles.getRolesForUser(users.eve, { anyScope: true, fullObjects: true }).map(obj => { delete obj._id; return obj }), [{ - role: { _id: 'user' }, - scope: null, - user: { _id: users.eve }, - inheritedRoles: [ - { _id: 'user' } - ] - }]) - }) - - it('delete role with overlapping hierarchical roles', function () { - Roles.createRole('role1') - Roles.createRole('role2') - Roles.createRole('COMMON_PERMISSION_1') - Roles.createRole('COMMON_PERMISSION_2') - Roles.createRole('COMMON_PERMISSION_3') - Roles.createRole('EXTRA_PERMISSION_ROLE_1') - Roles.createRole('EXTRA_PERMISSION_ROLE_2') - - Roles.addRolesToParent('COMMON_PERMISSION_1', 'role1') - Roles.addRolesToParent('COMMON_PERMISSION_2', 'role1') - Roles.addRolesToParent('COMMON_PERMISSION_3', 'role1') - Roles.addRolesToParent('EXTRA_PERMISSION_ROLE_1', 'role1') - - Roles.addRolesToParent('COMMON_PERMISSION_1', 'role2') - Roles.addRolesToParent('COMMON_PERMISSION_2', 'role2') - Roles.addRolesToParent('COMMON_PERMISSION_3', 'role2') - Roles.addRolesToParent('EXTRA_PERMISSION_ROLE_2', 'role2') - - Roles.addUsersToRoles(users.eve, 'role1') - Roles.addUsersToRoles(users.eve, 'role2') - - assert.isTrue(Roles.userIsInRole(users.eve, 'COMMON_PERMISSION_1')) - assert.isTrue(Roles.userIsInRole(users.eve, 'EXTRA_PERMISSION_ROLE_1')) - assert.isTrue(Roles.userIsInRole(users.eve, 'EXTRA_PERMISSION_ROLE_2')) - - assert.sameDeepMembers(Roles.getRolesForUser(users.eve, { anyScope: true, fullObjects: true }).map(obj => { delete obj._id; return obj }), [{ - role: { _id: 'role1' }, - scope: null, - user: { _id: users.eve }, - inheritedRoles: [ - { _id: 'role1' }, - { _id: 'COMMON_PERMISSION_1' }, - { _id: 'COMMON_PERMISSION_2' }, - { _id: 'COMMON_PERMISSION_3' }, - { _id: 'EXTRA_PERMISSION_ROLE_1' } - ] - }, { - role: { _id: 'role2' }, - scope: null, - user: { _id: users.eve }, - inheritedRoles: [ - { _id: 'role2' }, - { _id: 'COMMON_PERMISSION_1' }, - { _id: 'COMMON_PERMISSION_2' }, - { _id: 'COMMON_PERMISSION_3' }, - { _id: 'EXTRA_PERMISSION_ROLE_2' } - ] - }]) - - Roles.removeUsersFromRoles(users.eve, 'role2') - - assert.isTrue(Roles.userIsInRole(users.eve, 'COMMON_PERMISSION_1')) - assert.isTrue(Roles.userIsInRole(users.eve, 'EXTRA_PERMISSION_ROLE_1')) - assert.isFalse(Roles.userIsInRole(users.eve, 'EXTRA_PERMISSION_ROLE_2')) - - assert.sameDeepMembers(Roles.getRolesForUser(users.eve, { anyScope: true, fullObjects: true }).map(obj => { delete obj._id; return obj }), [{ - role: { _id: 'role1' }, - scope: null, - user: { _id: users.eve }, - inheritedRoles: [ - { _id: 'role1' }, - { _id: 'COMMON_PERMISSION_1' }, - { _id: 'COMMON_PERMISSION_2' }, - { _id: 'COMMON_PERMISSION_3' }, - { _id: 'EXTRA_PERMISSION_ROLE_1' } - ] - }]) - - Roles.addUsersToRoles(users.eve, 'role2') - - assert.isTrue(Roles.userIsInRole(users.eve, 'COMMON_PERMISSION_1')) - assert.isTrue(Roles.userIsInRole(users.eve, 'EXTRA_PERMISSION_ROLE_1')) - assert.isTrue(Roles.userIsInRole(users.eve, 'EXTRA_PERMISSION_ROLE_2')) - - assert.sameDeepMembers(Roles.getRolesForUser(users.eve, { anyScope: true, fullObjects: true }).map(obj => { delete obj._id; return obj }), [{ - role: { _id: 'role1' }, - scope: null, - user: { _id: users.eve }, - inheritedRoles: [ - { _id: 'role1' }, - { _id: 'COMMON_PERMISSION_1' }, - { _id: 'COMMON_PERMISSION_2' }, - { _id: 'COMMON_PERMISSION_3' }, - { _id: 'EXTRA_PERMISSION_ROLE_1' } - ] - }, { - role: { _id: 'role2' }, - scope: null, - user: { _id: users.eve }, - inheritedRoles: [ - { _id: 'role2' }, - { _id: 'COMMON_PERMISSION_1' }, - { _id: 'COMMON_PERMISSION_2' }, - { _id: 'COMMON_PERMISSION_3' }, - { _id: 'EXTRA_PERMISSION_ROLE_2' } - ] - }]) - - Roles.deleteRole('role2') - - assert.isTrue(Roles.userIsInRole(users.eve, 'COMMON_PERMISSION_1')) - assert.isTrue(Roles.userIsInRole(users.eve, 'EXTRA_PERMISSION_ROLE_1')) - assert.isFalse(Roles.userIsInRole(users.eve, 'EXTRA_PERMISSION_ROLE_2')) - - assert.sameDeepMembers(Roles.getRolesForUser(users.eve, { anyScope: true, fullObjects: true }).map(obj => { delete obj._id; return obj }), [{ - role: { _id: 'role1' }, - scope: null, - user: { _id: users.eve }, - inheritedRoles: [ - { _id: 'role1' }, - { _id: 'COMMON_PERMISSION_1' }, - { _id: 'COMMON_PERMISSION_2' }, - { _id: 'COMMON_PERMISSION_3' }, - { _id: 'EXTRA_PERMISSION_ROLE_1' } - ] - }]) - }) - - it('set parent on assigned role', function () { - Roles.createRole('admin') - Roles.createRole('EDIT_PERMISSION') - - Roles.addUsersToRoles(users.eve, 'EDIT_PERMISSION') - - assert.isTrue(Roles.userIsInRole(users.eve, 'EDIT_PERMISSION')) - assert.isFalse(Roles.userIsInRole(users.eve, 'admin')) - - assert.sameDeepMembers(Roles.getRolesForUser(users.eve, { anyScope: true, fullObjects: true }).map(obj => { delete obj._id; return obj }), [{ - role: { _id: 'EDIT_PERMISSION' }, - scope: null, - user: { _id: users.eve }, - inheritedRoles: [{ _id: 'EDIT_PERMISSION' }] - }]) - - Roles.addRolesToParent('EDIT_PERMISSION', 'admin') - - assert.isTrue(Roles.userIsInRole(users.eve, 'EDIT_PERMISSION')) - assert.isFalse(Roles.userIsInRole(users.eve, 'admin')) - - assert.sameDeepMembers(Roles.getRolesForUser(users.eve, { anyScope: true, fullObjects: true }).map(obj => { delete obj._id; return obj }), [{ - role: { _id: 'EDIT_PERMISSION' }, - scope: null, - user: { _id: users.eve }, - inheritedRoles: [{ _id: 'EDIT_PERMISSION' }] - }]) - }) - - it('remove parent on assigned role', function () { - Roles.createRole('admin') - Roles.createRole('EDIT_PERMISSION') - - Roles.addRolesToParent('EDIT_PERMISSION', 'admin') - - Roles.addUsersToRoles(users.eve, 'EDIT_PERMISSION') - - assert.isTrue(Roles.userIsInRole(users.eve, 'EDIT_PERMISSION')) - assert.isFalse(Roles.userIsInRole(users.eve, 'admin')) - - assert.sameDeepMembers(Roles.getRolesForUser(users.eve, { anyScope: true, fullObjects: true }).map(obj => { delete obj._id; return obj }), [{ - role: { _id: 'EDIT_PERMISSION' }, - scope: null, - user: { _id: users.eve }, - inheritedRoles: [{ _id: 'EDIT_PERMISSION' }] - }]) - - Roles.removeRolesFromParent('EDIT_PERMISSION', 'admin') - - assert.isTrue(Roles.userIsInRole(users.eve, 'EDIT_PERMISSION')) - assert.isFalse(Roles.userIsInRole(users.eve, 'admin')) - - assert.sameDeepMembers(Roles.getRolesForUser(users.eve, { anyScope: true, fullObjects: true }).map(obj => { delete obj._id; return obj }), [{ - role: { _id: 'EDIT_PERMISSION' }, - scope: null, - user: { _id: users.eve }, - inheritedRoles: [{ _id: 'EDIT_PERMISSION' }] - }]) - }) - - it('adding and removing extra role parents', function () { - Roles.createRole('admin') - Roles.createRole('user') - Roles.createRole('EDIT_PERMISSION') - - Roles.addRolesToParent('EDIT_PERMISSION', 'admin') - - Roles.addUsersToRoles(users.eve, 'EDIT_PERMISSION') - - assert.isTrue(Roles.userIsInRole(users.eve, 'EDIT_PERMISSION')) - assert.isFalse(Roles.userIsInRole(users.eve, 'admin')) - - assert.sameDeepMembers(Roles.getRolesForUser(users.eve, { anyScope: true, fullObjects: true }).map(obj => { delete obj._id; return obj }), [{ - role: { _id: 'EDIT_PERMISSION' }, - scope: null, - user: { _id: users.eve }, - inheritedRoles: [{ _id: 'EDIT_PERMISSION' }] - }]) - - Roles.addRolesToParent('EDIT_PERMISSION', 'user') - - assert.isTrue(Roles.userIsInRole(users.eve, 'EDIT_PERMISSION')) - assert.isFalse(Roles.userIsInRole(users.eve, 'admin')) - - assert.sameDeepMembers(Roles.getRolesForUser(users.eve, { anyScope: true, fullObjects: true }).map(obj => { delete obj._id; return obj }), [{ - role: { _id: 'EDIT_PERMISSION' }, - scope: null, - user: { _id: users.eve }, - inheritedRoles: [{ _id: 'EDIT_PERMISSION' }] - }]) - - Roles.removeRolesFromParent('EDIT_PERMISSION', 'user') - - assert.isTrue(Roles.userIsInRole(users.eve, 'EDIT_PERMISSION')) - assert.isFalse(Roles.userIsInRole(users.eve, 'admin')) - - assert.sameDeepMembers(Roles.getRolesForUser(users.eve, { anyScope: true, fullObjects: true }).map(obj => { delete obj._id; return obj }), [{ - role: { _id: 'EDIT_PERMISSION' }, - scope: null, - user: { _id: users.eve }, - inheritedRoles: [{ _id: 'EDIT_PERMISSION' }] - }]) - }) - - it('cyclic roles', function () { - Roles.createRole('admin') - Roles.createRole('editor') - Roles.createRole('user') - - Roles.addRolesToParent('editor', 'admin') - Roles.addRolesToParent('user', 'editor') - - assert.throws(function () { - Roles.addRolesToParent('admin', 'user') - }, /form a cycle/) - }) - - it('userIsInRole returns false for unknown roles', function () { - Roles.createRole('admin') - Roles.createRole('user') - Roles.createRole('editor') - Roles.addUsersToRoles(users.eve, ['admin', 'user']) - Roles.addUsersToRoles(users.eve, ['editor']) - - assert.isFalse(Roles.userIsInRole(users.eve, 'unknown')) - assert.isFalse(Roles.userIsInRole(users.eve, [])) - assert.isFalse(Roles.userIsInRole(users.eve, null)) - assert.isFalse(Roles.userIsInRole(users.eve, undefined)) - - assert.isFalse(Roles.userIsInRole(users.eve, 'unknown', { anyScope: true })) - assert.isFalse(Roles.userIsInRole(users.eve, [], { anyScope: true })) - assert.isFalse(Roles.userIsInRole(users.eve, null, { anyScope: true })) - assert.isFalse(Roles.userIsInRole(users.eve, undefined, { anyScope: true })) - - assert.isFalse(Roles.userIsInRole(users.eve, ['Role1', 'Role2', undefined], 'GroupName')) - }) - - it('userIsInRole returns false if user is a function', function () { - Roles.createRole('admin') - Roles.addUsersToRoles(users.eve, ['admin']) - - assert.isFalse(Roles.userIsInRole(() => {}, 'admin')) - }) - - describe('isParentOf', function () { - it('returns false for unknown roles', function () { - Roles.createRole('admin') - - assert.isFalse(Roles.isParentOf('admin', 'unknown')) - assert.isFalse(Roles.isParentOf('admin', null)) - assert.isFalse(Roles.isParentOf('admin', undefined)) - - assert.isFalse(Roles.isParentOf('unknown', 'admin')) - assert.isFalse(Roles.isParentOf(null, 'admin')) - assert.isFalse(Roles.isParentOf(undefined, 'admin')) - }) - - it('returns false if role is not parent of', function () { - Roles.createRole('admin') - Roles.createRole('editor') - Roles.createRole('user') - Roles.addRolesToParent(['editor'], 'admin') - Roles.addRolesToParent(['user'], 'editor') - - assert.isFalse(Roles.isParentOf('user', 'admin')) - assert.isFalse(Roles.isParentOf('editor', 'admin')) - }) - - it('returns true if role is parent of the demanded role', function () { - Roles.createRole('admin') - Roles.createRole('editor') - Roles.createRole('user') - Roles.addRolesToParent(['editor'], 'admin') - Roles.addRolesToParent(['user'], 'editor') - - assert.isTrue(Roles.isParentOf('admin', 'user')) - assert.isTrue(Roles.isParentOf('editor', 'user')) - assert.isTrue(Roles.isParentOf('admin', 'editor')) - - assert.isTrue(Roles.isParentOf('admin', 'admin')) - assert.isTrue(Roles.isParentOf('editor', 'editor')) - assert.isTrue(Roles.isParentOf('user', 'user')) - }) - }) -}) diff --git a/roles/tests/serverAsync.js b/roles/tests/serverAsync.js index 8d118aef..9c7ac4e5 100644 --- a/roles/tests/serverAsync.js +++ b/roles/tests/serverAsync.js @@ -6,8 +6,7 @@ import chai, { assert } from 'chai' import chaiAsPromised from 'chai-as-promised' // To ensure that the files are loaded for coverage -import '../roles_server' -import '../roles_common' +import '../roles_common_async' chai.use(chaiAsPromised) From 5f3485b031c3c9cce79b58d9de958e5911d7120a Mon Sep 17 00:00:00 2001 From: Jan Dvorak Date: Mon, 8 Apr 2024 17:11:44 +0200 Subject: [PATCH 11/45] Fix lint tests --- roles/roles_client.js | 2 +- roles/roles_server.js | 5 +++-- 2 files changed, 4 insertions(+), 3 deletions(-) diff --git a/roles/roles_client.js b/roles/roles_client.js index afb80711..84aeff80 100644 --- a/roles/roles_client.js +++ b/roles/roles_client.js @@ -1,4 +1,4 @@ -/* global Meteor, Roles */ +/* global Roles */ import { Meteor } from 'meteor/meteor' /** diff --git a/roles/roles_server.js b/roles/roles_server.js index ead157fb..0bf50828 100644 --- a/roles/roles_server.js +++ b/roles/roles_server.js @@ -3,13 +3,14 @@ import { Meteor } from 'meteor/meteor' const indexFnAssignment = Meteor.roleAssignment.createIndexAsync.bind(Meteor.roleAssignment) const indexFnRoles = Meteor.roles.createIndexAsync.bind(Meteor.roles) -[ +const indexes = [ { 'user._id': 1, 'inheritedRoles._id': 1, scope: 1 }, { 'user._id': 1, 'role._id': 1, scope: 1 }, { 'role._id': 1 }, { scope: 1, 'user._id': 1, 'inheritedRoles._id': 1 }, // Adding userId and roleId might speed up other queries depending on the first index { 'inheritedRoles._id': 1 } -].forEach(index => indexFnAssignment(index)) +] +indexes.forEach(index => indexFnAssignment(index)) indexFnRoles({ 'children._id': 1 }) /* From a5614b99ad1d1184e45a5b1c531cba646c03908f Mon Sep 17 00:00:00 2001 From: Jan Dvorak Date: Mon, 8 Apr 2024 17:14:30 +0200 Subject: [PATCH 12/45] Add Meteor 3.0-beta.7 to the test suite --- .github/workflows/testsuite.yml | 17 +++++++++-------- 1 file changed, 9 insertions(+), 8 deletions(-) diff --git a/.github/workflows/testsuite.yml b/.github/workflows/testsuite.yml index 410363ac..1af3a612 100644 --- a/.github/workflows/testsuite.yml +++ b/.github/workflows/testsuite.yml @@ -17,15 +17,15 @@ jobs: - name: setup node uses: actions/setup-node@v4 with: - node-version: 16 + node-version: 20 - name: cache dependencies uses: actions/cache@v3 with: path: ~/.npm - key: ${{ runner.os }}-node-16-${{ hashFiles('**/package-lock.json') }} + key: ${{ runner.os }}-node-20-${{ hashFiles('**/package-lock.json') }} restore-keys: | - ${{ runner.os }}-node-16- + ${{ runner.os }}-node-20- - run: cd testapp && npm ci && npm run setup && npm run lint @@ -36,8 +36,9 @@ jobs: strategy: matrix: meteorRelease: - - '2.8.0' - - '2.14' + - '2.8.1' + - '2.15' + - '3.0-beta.7' # Latest version steps: - name: Checkout code @@ -46,7 +47,7 @@ jobs: - name: Install Node.js uses: actions/setup-node@v4 with: - node-version: 16 + node-version: 20 - name: Setup meteor ${{ matrix.meteorRelease }} uses: meteorengineer/setup-meteor@v1 @@ -57,8 +58,8 @@ jobs: uses: actions/cache@v3 with: path: ~/.npm - key: ${{ runner.os }}-node-16-${{ hashFiles('**/package-lock.json') }} + key: ${{ runner.os }}-node-20-${{ hashFiles('**/package-lock.json') }} restore-keys: | - ${{ runner.os }}-node-16- + ${{ runner.os }}-node-20- - run: cd testapp && npm ci && npm run setup && npm run test From ee76581dd0ded02a48e886e3c5ab1fa8911496ff Mon Sep 17 00:00:00 2001 From: Jan Dvorak Date: Mon, 8 Apr 2024 17:15:44 +0200 Subject: [PATCH 13/45] Remove sync tests from package.js --- package.js | 1 - 1 file changed, 1 deletion(-) diff --git a/package.js b/package.js index 498bc075..0614adda 100644 --- a/package.js +++ b/package.js @@ -56,7 +56,6 @@ Package.onTest(function (api) { 'mongo' ], both) - api.addFiles('roles/tests/server.js', 'server') api.addFiles('roles/tests/serverAsync.js', 'server') api.addFiles('roles/tests/client.js', 'client') api.addFiles('roles/tests/clientAsync.js', 'client') From d371fedd4180f809f5ebf8b546e21d00027f5bdb Mon Sep 17 00:00:00 2001 From: Jan Dvorak Date: Mon, 8 Apr 2024 17:22:51 +0200 Subject: [PATCH 14/45] Fix missing _getParentRoleNames in async common --- History.md | 2 +- roles/roles_common_async.js | 6 +++--- 2 files changed, 4 insertions(+), 4 deletions(-) diff --git a/History.md b/History.md index 300ea913..ba92c4e3 100644 --- a/History.md +++ b/History.md @@ -3,7 +3,7 @@ ## v4.0.0 * BREAKING: Synchronous functions are now available only on client side -* * BREAKING: Migration functions for past versions are no longer available +* BREAKING: Migration functions for past versions are no longer available * UI Helpers now use `console.debug` for debugging messages * `RolesCollection` and `RoleAssignmentsCollection` can now be exported in addition to being accessed via `Meteor.roles` and `Meteor.roleAssignment` diff --git a/roles/roles_common_async.js b/roles/roles_common_async.js index b6cf119a..860bf685 100644 --- a/roles/roles_common_async.js +++ b/roles/roles_common_async.js @@ -138,7 +138,7 @@ Object.assign(Roles, { do { // For all roles who have it as a dependency ... - roles = Roles._getParentRoleNames( + roles = await Roles._getParentRoleNamesAsync( await Meteor.roles.findOneAsync({ _id: roleName }) ) @@ -652,9 +652,9 @@ Object.assign(Roles, { * Returns an array of role names the given role name is a child of. * * @example - * Roles._getParentRoleNames({ _id: 'admin', children; [] }) + * Roles._getParentRoleNamesAsync({ _id: 'admin', children; [] }) * - * @method _getParentRoleNames + * @method _getParentRoleNamesAsync * @param {object} role The role object * @returns {Promise} * @private From 9ea1ea0e88826a4181f5a0ab1af6119da0ab94cb Mon Sep 17 00:00:00 2001 From: Jan Dvorak Date: Mon, 8 Apr 2024 17:27:03 +0200 Subject: [PATCH 15/45] _addUserToRole async fix --- roles/roles_common_async.js | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/roles/roles_common_async.js b/roles/roles_common_async.js index 860bf685..141a4a2a 100644 --- a/roles/roles_common_async.js +++ b/roles/roles_common_async.js @@ -547,7 +547,7 @@ Object.assign(Roles, { // and then add all for (const role of roles) { - await Roles._addUserToRole(id, role, options) + await Roles._addUserToRoleAsync(id, role, options) } } }, @@ -555,7 +555,7 @@ Object.assign(Roles, { /** * Add one user to one role. * - * @method _addUserToRole + * @method _addUserToRoleAsync * @param {String} userId The user ID. * @param {String} roleName Name of the role to add the user to. The role have to exist. * @param {Object} options Options: From 87dd82ba9e92db8927adde3dc5b8c8209fb31ec4 Mon Sep 17 00:00:00 2001 From: Jan Dvorak Date: Mon, 8 Apr 2024 17:29:31 +0200 Subject: [PATCH 16/45] Fix _removeUserFromRole async version in tests --- roles/roles_common_async.js | 2 +- roles/tests/serverAsync.js | 2 +- 2 files changed, 2 insertions(+), 2 deletions(-) diff --git a/roles/roles_common_async.js b/roles/roles_common_async.js index 141a4a2a..0a161366 100644 --- a/roles/roles_common_async.js +++ b/roles/roles_common_async.js @@ -763,7 +763,7 @@ Object.assign(Roles, { /** * Remove one user from one role. * - * @method _removeUserFromRole + * @method _removeUserFromRoleAsync * @param {String} userId The user ID. * @param {String} roleName Name of the role to add the user to. The role have to exist. * @param {Object} options Options: diff --git a/roles/tests/serverAsync.js b/roles/tests/serverAsync.js index 9c7ac4e5..47c55cf2 100644 --- a/roles/tests/serverAsync.js +++ b/roles/tests/serverAsync.js @@ -1484,7 +1484,7 @@ describe('roles async', async function () { inheritedRoles: [{ _id: 'admin' }] }]) - Roles._removeUserFromRole(users.eve, 'admin', { scope: null }) + await Roles._removeUserFromRoleAsync(users.eve, 'admin', { scope: null }) const rolesForUser2 = await Roles.getRolesForUserAsync(users.eve, { anyScope: true, fullObjects: true }) assert.sameDeepMembers(rolesForUser2.map(obj => { delete obj._id; return obj }), []) From 8c479ecb7a3ef3067cff67009fedfd2a6e22275d Mon Sep 17 00:00:00 2001 From: Jan Dvorak Date: Mon, 8 Apr 2024 17:42:57 +0200 Subject: [PATCH 17/45] Published alanning:roles@4.0.0-alpha.1 --- .versions | 14 +++++++------- 1 file changed, 7 insertions(+), 7 deletions(-) diff --git a/.versions b/.versions index b6e310e1..3e6c79d1 100644 --- a/.versions +++ b/.versions @@ -1,5 +1,5 @@ -accounts-base@2.2.9 -alanning:roles@3.6.2 +accounts-base@2.2.10 +alanning:roles@4.0.0-alpha.1 allow-deny@1.1.1 babel-compiler@7.10.5 babel-runtime@1.5.1 @@ -27,10 +27,10 @@ id-map@1.1.1 inter-process-messaging@0.1.1 lmieulet:meteor-coverage@4.1.0 lmieulet:meteor-legacy-coverage@0.1.0 -local-test:alanning:roles@3.6.2 +local-test:alanning:roles@4.0.0-alpha.1 localstorage@1.2.0 logging@1.3.3 -meteor@1.11.4 +meteor@1.11.5 meteortesting:browser-tests@1.4.2 meteortesting:mocha@2.1.0 meteortesting:mocha-core@8.0.1 @@ -55,8 +55,8 @@ routepolicy@1.1.1 socket-stream-client@0.5.2 tracker@1.3.3 typescript@4.9.5 -underscore@1.0.13 +underscore@1.6.0 url@1.3.2 -webapp@1.13.6 +webapp@1.13.8 webapp-hashing@1.1.1 -zodern:types@1.0.11 +zodern:types@1.0.13 From ac92c9b6de33916a42f7a44f2406911f3f007905 Mon Sep 17 00:00:00 2001 From: Jan Dvorak Date: Sat, 4 May 2024 23:51:35 +0200 Subject: [PATCH 18/45] Add missing ddp dependency --- package.js | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/package.js b/package.js index 0614adda..e596728b 100644 --- a/package.js +++ b/package.js @@ -17,7 +17,8 @@ Package.onUse(function (api) { 'accounts-base', 'tracker', 'mongo', - 'check' + 'check', + 'ddp' ], both) api.use('zodern:types@1.0.13') From c70d7878c19dd393dc65cb9e4172c33497a09bae Mon Sep 17 00:00:00 2001 From: Jan Dvorak Date: Sat, 4 May 2024 23:52:01 +0200 Subject: [PATCH 19/45] 4.0-alpha.2 release prep --- package.js | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/package.js b/package.js index e596728b..7e044fbc 100644 --- a/package.js +++ b/package.js @@ -2,13 +2,13 @@ Package.describe({ summary: 'Authorization package for Meteor', - version: '4.0.0-alpha.1', + version: '4.0.0-alpha.2', git: 'https://github.com/Meteor-Community-Packages/meteor-roles.git', name: 'alanning:roles' }) Package.onUse(function (api) { - api.versionsFrom(['2.8.1', '3.0-beta.7']) + api.versionsFrom(['2.8.1', '3.0-rc.0']) const both = ['client', 'server'] From 54130f46b26286c147a1682923c76d88ac423c32 Mon Sep 17 00:00:00 2001 From: Jan Dvorak Date: Sat, 4 May 2024 23:53:29 +0200 Subject: [PATCH 20/45] Published alanning:roles@4.0.0-alpha.3 --- .versions | 4 ++-- package.js | 2 +- 2 files changed, 3 insertions(+), 3 deletions(-) diff --git a/.versions b/.versions index 3e6c79d1..2a70a936 100644 --- a/.versions +++ b/.versions @@ -1,5 +1,5 @@ accounts-base@2.2.10 -alanning:roles@4.0.0-alpha.1 +alanning:roles@4.0.0-alpha.3 allow-deny@1.1.1 babel-compiler@7.10.5 babel-runtime@1.5.1 @@ -27,7 +27,7 @@ id-map@1.1.1 inter-process-messaging@0.1.1 lmieulet:meteor-coverage@4.1.0 lmieulet:meteor-legacy-coverage@0.1.0 -local-test:alanning:roles@4.0.0-alpha.1 +local-test:alanning:roles@4.0.0-alpha.3 localstorage@1.2.0 logging@1.3.3 meteor@1.11.5 diff --git a/package.js b/package.js index 7e044fbc..2ec145c7 100644 --- a/package.js +++ b/package.js @@ -2,7 +2,7 @@ Package.describe({ summary: 'Authorization package for Meteor', - version: '4.0.0-alpha.2', + version: '4.0.0-alpha.3', git: 'https://github.com/Meteor-Community-Packages/meteor-roles.git', name: 'alanning:roles' }) From a29d818aa01d93e1da47445514cdfad281bb29ae Mon Sep 17 00:00:00 2001 From: Jan Dvorak Date: Sat, 4 May 2024 23:58:10 +0200 Subject: [PATCH 21/45] Update test suite to use 3.0-rc.0 --- .github/workflows/testsuite.yml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.github/workflows/testsuite.yml b/.github/workflows/testsuite.yml index 1af3a612..393f8e60 100644 --- a/.github/workflows/testsuite.yml +++ b/.github/workflows/testsuite.yml @@ -38,7 +38,7 @@ jobs: meteorRelease: - '2.8.1' - '2.15' - - '3.0-beta.7' + - '3.0-rc.0' # Latest version steps: - name: Checkout code From 72c343bdbc06a656e0edec356a27625f1e53a7bd Mon Sep 17 00:00:00 2001 From: Jan Dvorak Date: Mon, 6 May 2024 17:39:20 +0200 Subject: [PATCH 22/45] Use collections directly internally --- roles/roles_client.js | 84 +++++++++++++++---------------- roles/roles_common_async.js | 98 ++++++++++++++++++------------------- roles/roles_server.js | 5 +- 3 files changed, 95 insertions(+), 92 deletions(-) diff --git a/roles/roles_client.js b/roles/roles_client.js index 84aeff80..abe4de70 100644 --- a/roles/roles_client.js +++ b/roles/roles_client.js @@ -1,6 +1,8 @@ /* global Roles */ import { Meteor } from 'meteor/meteor' +import { RolesCollection, RoleAssignmentCollection } from './roles_common_async' + /** * Provides functions related to user authorization. Compatible with built-in Meteor accounts packages. * @@ -15,7 +17,7 @@ import { Meteor } from 'meteor/meteor' * * Example: `{_id: 'admin', children: [{_id: 'editor'}]}` * - * The assignment of a role to a user is stored in a collection, accessible through `Meteor.roleAssignment`. + * The assignment of a role to a user is stored in a collection, accessible through `RoleAssignmentCollection`. * It's documents consist of * - `_id`: Internal MongoDB id * - `role`: A role object which got assigned. Usually only contains the `_id` property @@ -63,7 +65,7 @@ Object.assign(Roles, { unlessExists: false }, options) - const result = Meteor.roles.upsert({ _id: roleName }, { $setOnInsert: { children: [] } }) + const result = RolesCollection.upsert({ _id: roleName }, { $setOnInsert: { children: [] } }) if (!result.insertedId) { if (options.unlessExists) return null @@ -89,16 +91,16 @@ Object.assign(Roles, { Roles._checkRoleName(roleName) // Remove all assignments - Meteor.roleAssignment.remove({ + RoleAssignmentCollection.remove({ 'role._id': roleName }) do { // For all roles who have it as a dependency ... - roles = Roles._getParentRoleNames(Meteor.roles.findOne({ _id: roleName })) + roles = Roles._getParentRoleNames(RolesCollection.findOne({ _id: roleName })) - Meteor.roles.find({ _id: { $in: roles } }).fetch().forEach(r => { - Meteor.roles.update({ + RolesCollection.find({ _id: { $in: roles } }).fetch().forEach(r => { + RolesCollection.update({ _id: r._id }, { $pull: { @@ -108,8 +110,8 @@ Object.assign(Roles, { } }) - inheritedRoles = Roles._getInheritedRoleNames(Meteor.roles.findOne({ _id: r._id })) - Meteor.roleAssignment.update({ + inheritedRoles = Roles._getInheritedRoleNames(RolesCollection.findOne({ _id: r._id })) + RoleAssignmentCollection.update({ 'role._id': r._id }, { $set: { @@ -120,7 +122,7 @@ Object.assign(Roles, { } while (roles.length > 0) // And finally remove the role itself - Meteor.roles.remove({ _id: roleName }) + RolesCollection.remove({ _id: roleName }) }, /** @@ -139,7 +141,7 @@ Object.assign(Roles, { if (oldName === newName) return - const role = Meteor.roles.findOne({ _id: oldName }) + const role = RolesCollection.findOne({ _id: oldName }) if (!role) { throw new Error('Role \'' + oldName + '\' does not exist.') @@ -147,10 +149,10 @@ Object.assign(Roles, { role._id = newName - Meteor.roles.insert(role) + RolesCollection.insert(role) do { - count = Meteor.roleAssignment.update({ + count = RoleAssignmentCollection.update({ 'role._id': oldName }, { $set: { @@ -160,7 +162,7 @@ Object.assign(Roles, { } while (count > 0) do { - count = Meteor.roleAssignment.update({ + count = RoleAssignmentCollection.update({ 'inheritedRoles._id': oldName }, { $set: { @@ -170,7 +172,7 @@ Object.assign(Roles, { } while (count > 0) do { - count = Meteor.roles.update({ + count = RolesCollection.update({ 'children._id': oldName }, { $set: { @@ -179,7 +181,7 @@ Object.assign(Roles, { }, { multi: true }) } while (count > 0) - Meteor.roles.remove({ _id: oldName }) + RolesCollection.remove({ _id: oldName }) }, /** @@ -214,7 +216,7 @@ Object.assign(Roles, { Roles._checkRoleName(parentName) // query to get role's children - const role = Meteor.roles.findOne({ _id: roleName }) + const role = RolesCollection.findOne({ _id: roleName }) if (!role) { throw new Error('Role \'' + roleName + '\' does not exist.') @@ -225,7 +227,7 @@ Object.assign(Roles, { throw new Error('Roles \'' + roleName + '\' and \'' + parentName + '\' would form a cycle.') } - const count = Meteor.roles.update({ + const count = RolesCollection.update({ _id: parentName, 'children._id': { $ne: role._id @@ -242,7 +244,7 @@ Object.assign(Roles, { // already a subrole; in any case we do not have anything more to do if (!count) return - Meteor.roleAssignment.update({ + RoleAssignmentCollection.update({ 'inheritedRoles._id': parentName }, { $push: { @@ -284,13 +286,13 @@ Object.assign(Roles, { // check for role existence // this would not really be needed, but we are trying to match addRolesToParent - const role = Meteor.roles.findOne({ _id: roleName }, { fields: { _id: 1 } }) + const role = RolesCollection.findOne({ _id: roleName }, { fields: { _id: 1 } }) if (!role) { throw new Error('Role \'' + roleName + '\' does not exist.') } - const count = Meteor.roles.update({ + const count = RolesCollection.update({ _id: parentName }, { $pull: { @@ -305,11 +307,11 @@ Object.assign(Roles, { if (!count) return // For all roles who have had it as a dependency ... - const roles = [...Roles._getParentRoleNames(Meteor.roles.findOne({ _id: parentName })), parentName] + const roles = [...Roles._getParentRoleNames(RolesCollection.findOne({ _id: parentName })), parentName] - Meteor.roles.find({ _id: { $in: roles } }).fetch().forEach(r => { - const inheritedRoles = Roles._getInheritedRoleNames(Meteor.roles.findOne({ _id: r._id })) - Meteor.roleAssignment.update({ + RolesCollection.find({ _id: { $in: roles } }).fetch().forEach(r => { + const inheritedRoles = Roles._getInheritedRoleNames(RolesCollection.findOne({ _id: r._id })) + RoleAssignmentCollection.update({ 'role._id': r._id, 'inheritedRoles._id': role._id }, { @@ -425,7 +427,7 @@ Object.assign(Roles, { selector.scope = options.scope } - Meteor.roleAssignment.remove(selector) + RoleAssignmentCollection.remove(selector) // and then add all roles.forEach(function (role) { @@ -454,7 +456,7 @@ Object.assign(Roles, { return } - const role = Meteor.roles.findOne({ _id: roleName }, { fields: { children: 1 } }) + const role = RolesCollection.findOne({ _id: roleName }, { fields: { children: 1 } }) if (!role) { if (options.ifExists) { @@ -465,7 +467,7 @@ Object.assign(Roles, { } // This might create duplicates, because we don't have a unique index, but that's all right. In case there are two, withdrawing the role will effectively kill them both. - const res = Meteor.roleAssignment.upsert({ + const res = RoleAssignmentCollection.upsert({ 'user._id': userId, 'role._id': roleName, scope: options.scope @@ -478,7 +480,7 @@ Object.assign(Roles, { }) if (res.insertedId) { - Meteor.roleAssignment.update({ _id: res.insertedId }, { + RoleAssignmentCollection.update({ _id: res.insertedId }, { $set: { inheritedRoles: [roleName, ...Roles._getInheritedRoleNames(role)].map(r => ({ _id: r })) } @@ -507,7 +509,7 @@ Object.assign(Roles, { const parentRoles = new Set([role._id]) parentRoles.forEach(roleName => { - Meteor.roles.find({ 'children._id': roleName }).fetch().forEach(parentRole => { + RolesCollection.find({ 'children._id': roleName }).fetch().forEach(parentRole => { parentRoles.add(parentRole._id) }) }) @@ -533,7 +535,7 @@ Object.assign(Roles, { const nestedRoles = new Set([role]) nestedRoles.forEach(r => { - const roles = Meteor.roles.find({ _id: { $in: r.children.map(r => r._id) } }, { fields: { children: 1 } }).fetch() + const roles = RolesCollection.find({ _id: { $in: r.children.map(r => r._id) } }, { fields: { children: 1 } }).fetch() roles.forEach(r2 => { inheritedRoles.add(r2._id) @@ -617,7 +619,7 @@ Object.assign(Roles, { selector.scope = options.scope } - Meteor.roleAssignment.remove(selector) + RoleAssignmentCollection.remove(selector) }, /** @@ -684,7 +686,7 @@ Object.assign(Roles, { return roles.some((roleName) => { selector['inheritedRoles._id'] = roleName - return Meteor.roleAssignment.find(selector, { limit: 1 }).count() > 0 + return RoleAssignmentCollection.find(selector, { limit: 1 }).count() > 0 }) }, @@ -748,7 +750,7 @@ Object.assign(Roles, { delete filter.fields } - const roles = Meteor.roleAssignment.find(selector, filter).fetch() + const roles = RoleAssignmentCollection.find(selector, filter).fetch() if (options.fullObjects) { return roles @@ -769,14 +771,14 @@ Object.assign(Roles, { * * @method getAllRoles * @param {Object} queryOptions Options which are passed directly - * through to `Meteor.roles.find(query, options)`. + * through to `RolesCollection.find(query, options)`. * @return {Cursor} Cursor of existing roles. * @static */ getAllRoles: function (queryOptions) { queryOptions = queryOptions || { sort: { _id: 1 } } - return Meteor.roles.find({}, queryOptions) + return RolesCollection.find({}, queryOptions) }, /** @@ -824,7 +826,7 @@ Object.assign(Roles, { * roles will also be checked * - `anyScope`: if set, role can be in any scope (`scope` option is ignored) * - `queryOptions`: options which are passed directly - * through to `Meteor.roleAssignment.find(query, options)` + * through to `RoleAssignmentCollection.find(query, options)` * * Alternatively, it can be a scope name string. * @return {Cursor} Cursor of user assignments for roles. @@ -854,7 +856,7 @@ Object.assign(Roles, { * * Alternatively, it can be a scope name string. * @param {Object} [filter] Options which are passed directly - * through to `Meteor.roleAssignment.find(query, options)` + * through to `RoleAssignmentCollection.find(query, options)` * @return {Object} Cursor to the assignment documents * @private * @static @@ -886,7 +888,7 @@ Object.assign(Roles, { } } - return Meteor.roleAssignment.find(selector, filter) + return RoleAssignmentCollection.find(selector, filter) }, /** @@ -937,7 +939,7 @@ Object.assign(Roles, { selector['inheritedRoles._id'] = { $in: roles } } - const scopes = Meteor.roleAssignment.find(selector, { fields: { scope: 1 } }).fetch().map(obi => obi.scope) + const scopes = RoleAssignmentCollection.find(selector, { fields: { scope: 1 } }).fetch().map(obi => obi.scope) return [...new Set(scopes)] }, @@ -961,7 +963,7 @@ Object.assign(Roles, { if (oldName === newName) return do { - count = Meteor.roleAssignment.update({ + count = RoleAssignmentCollection.update({ scope: oldName }, { $set: { @@ -983,7 +985,7 @@ Object.assign(Roles, { removeScope: function (name) { Roles._checkScopeName(name) - Meteor.roleAssignment.remove({ scope: name }) + RoleAssignmentCollection.remove({ scope: name }) }, /** diff --git a/roles/roles_common_async.js b/roles/roles_common_async.js index 0a161366..c63c91ef 100644 --- a/roles/roles_common_async.js +++ b/roles/roles_common_async.js @@ -92,16 +92,16 @@ Object.assign(Roles, { let insertedId = null - const existingRole = await Meteor.roles.findOneAsync({ _id: roleName }) + const existingRole = await RolesCollection.findOneAsync({ _id: roleName }) if (existingRole) { - await Meteor.roles.updateAsync( + await RolesCollection.updateAsync( { _id: roleName }, { $setOnInsert: { children: [] } } ) return null } else { - insertedId = await Meteor.roles.insertAsync({ + insertedId = await RolesCollection.insertAsync({ _id: roleName, children: [] }) @@ -132,20 +132,20 @@ Object.assign(Roles, { Roles._checkRoleName(roleName) // Remove all assignments - await Meteor.roleAssignment.removeAsync({ + await RoleAssignmentCollection.removeAsync({ 'role._id': roleName }) do { // For all roles who have it as a dependency ... roles = await Roles._getParentRoleNamesAsync( - await Meteor.roles.findOneAsync({ _id: roleName }) + await RolesCollection.findOneAsync({ _id: roleName }) ) - for (const r of await Meteor.roles + for (const r of await RolesCollection .find({ _id: { $in: roles } }) .fetchAsync()) { - await Meteor.roles.updateAsync( + await RolesCollection.updateAsync( { _id: r._id }, @@ -159,9 +159,9 @@ Object.assign(Roles, { ) inheritedRoles = await Roles._getInheritedRoleNamesAsync( - await Meteor.roles.findOneAsync({ _id: r._id }) + await RolesCollection.findOneAsync({ _id: r._id }) ) - await Meteor.roleAssignment.updateAsync( + await RoleAssignmentCollection.updateAsync( { 'role._id': r._id }, @@ -178,7 +178,7 @@ Object.assign(Roles, { } while (roles.length > 0) // And finally remove the role itself - await Meteor.roles.removeAsync({ _id: roleName }) + await RolesCollection.removeAsync({ _id: roleName }) }, /** @@ -198,7 +198,7 @@ Object.assign(Roles, { if (oldName === newName) return - const role = await Meteor.roles.findOneAsync({ _id: oldName }) + const role = await RolesCollection.findOneAsync({ _id: oldName }) if (!role) { throw new Error("Role '" + oldName + "' does not exist.") @@ -206,10 +206,10 @@ Object.assign(Roles, { role._id = newName - await Meteor.roles.insertAsync(role) + await RolesCollection.insertAsync(role) do { - count = await Meteor.roleAssignment.updateAsync( + count = await RoleAssignmentCollection.updateAsync( { 'role._id': oldName }, @@ -223,7 +223,7 @@ Object.assign(Roles, { } while (count > 0) do { - count = await Meteor.roleAssignment.updateAsync( + count = await RoleAssignmentCollection.updateAsync( { 'inheritedRoles._id': oldName }, @@ -237,7 +237,7 @@ Object.assign(Roles, { } while (count > 0) do { - count = await Meteor.roles.updateAsync( + count = await RolesCollection.updateAsync( { 'children._id': oldName }, @@ -250,7 +250,7 @@ Object.assign(Roles, { ) } while (count > 0) - await Meteor.roles.removeAsync({ _id: oldName }) + await RolesCollection.removeAsync({ _id: oldName }) }, /** @@ -287,7 +287,7 @@ Object.assign(Roles, { Roles._checkRoleName(parentName) // query to get role's children - const role = await Meteor.roles.findOneAsync({ _id: roleName }) + const role = await RolesCollection.findOneAsync({ _id: roleName }) if (!role) { throw new Error("Role '" + roleName + "' does not exist.") @@ -300,7 +300,7 @@ Object.assign(Roles, { ) } - const count = await Meteor.roles.updateAsync( + const count = await RolesCollection.updateAsync( { _id: parentName, 'children._id': { @@ -320,7 +320,7 @@ Object.assign(Roles, { // already a sub-role; in any case we do not have anything more to do if (!count) return - await Meteor.roleAssignment.updateAsync( + await RoleAssignmentCollection.updateAsync( { 'inheritedRoles._id': parentName }, @@ -373,7 +373,7 @@ Object.assign(Roles, { // check for role existence // this would not really be needed, but we are trying to match addRolesToParent - const role = await Meteor.roles.findOneAsync( + const role = await RolesCollection.findOneAsync( { _id: roleName }, { fields: { _id: 1 } } ) @@ -382,7 +382,7 @@ Object.assign(Roles, { throw new Error("Role '" + roleName + "' does not exist.") } - const count = await Meteor.roles.updateAsync( + const count = await RolesCollection.updateAsync( { _id: parentName }, @@ -402,18 +402,18 @@ Object.assign(Roles, { // For all roles who have had it as a dependency ... const roles = [ ...(await Roles._getParentRoleNamesAsync( - await Meteor.roles.findOneAsync({ _id: parentName }) + await RolesCollection.findOneAsync({ _id: parentName }) )), parentName ] - for (const r of await Meteor.roles + for (const r of await RolesCollection .find({ _id: { $in: roles } }) .fetchAsync()) { const inheritedRoles = await Roles._getInheritedRoleNamesAsync( - await Meteor.roles.findOneAsync({ _id: r._id }) + await RolesCollection.findOneAsync({ _id: r._id }) ) - await Meteor.roleAssignment.updateAsync( + await RoleAssignmentCollection.updateAsync( { 'role._id': r._id, 'inheritedRoles._id': role._id @@ -543,7 +543,7 @@ Object.assign(Roles, { selector.scope = options.scope } - await Meteor.roleAssignment.removeAsync(selector) + await RoleAssignmentCollection.removeAsync(selector) // and then add all for (const role of roles) { @@ -573,7 +573,7 @@ Object.assign(Roles, { return } - const role = await Meteor.roles.findOneAsync( + const role = await RolesCollection.findOneAsync( { _id: roleName }, { fields: { children: 1 } } ) @@ -588,7 +588,7 @@ Object.assign(Roles, { // This might create duplicates, because we don't have a unique index, but that's all right. In case there are two, withdrawing the role will effectively kill them both. // TODO revisit this - /* const res = await Meteor.roleAssignment.upsertAsync( + /* const res = await RoleAssignmentCollection.upsertAsync( { "user._id": userId, "role._id": roleName, @@ -602,7 +602,7 @@ Object.assign(Roles, { }, } ); */ - const existingAssignment = await Meteor.roleAssignment.findOneAsync({ + const existingAssignment = await RoleAssignmentCollection.findOneAsync({ 'user._id': userId, 'role._id': roleName, scope: options.scope @@ -611,7 +611,7 @@ Object.assign(Roles, { let insertedId let res if (existingAssignment) { - await Meteor.roleAssignment.updateAsync(existingAssignment._id, { + await RoleAssignmentCollection.updateAsync(existingAssignment._id, { $set: { user: { _id: userId }, role: { _id: roleName }, @@ -619,9 +619,9 @@ Object.assign(Roles, { } }) - res = await Meteor.roleAssignment.findOneAsync(existingAssignment._id) + res = await RoleAssignmentCollection.findOneAsync(existingAssignment._id) } else { - insertedId = await Meteor.roleAssignment.insertAsync({ + insertedId = await RoleAssignmentCollection.insertAsync({ user: { _id: userId }, role: { _id: roleName }, scope: options.scope @@ -629,7 +629,7 @@ Object.assign(Roles, { } if (insertedId) { - await Meteor.roleAssignment.updateAsync( + await RoleAssignmentCollection.updateAsync( { _id: insertedId }, { $set: { @@ -641,7 +641,7 @@ Object.assign(Roles, { } ) - res = await Meteor.roleAssignment.findOneAsync({ _id: insertedId }) + res = await RoleAssignmentCollection.findOneAsync({ _id: insertedId }) } res.insertedId = insertedId // For backward compatibility @@ -668,7 +668,7 @@ Object.assign(Roles, { const parentRoles = new Set([role._id]) for (const roleName of parentRoles) { - for (const parentRole of await Meteor.roles + for (const parentRole of await RolesCollection .find({ 'children._id': roleName }) .fetchAsync()) { parentRoles.add(parentRole._id) @@ -697,7 +697,7 @@ Object.assign(Roles, { const nestedRoles = new Set([role]) for (const r of nestedRoles) { - const roles = await Meteor.roles + const roles = await RolesCollection .find( { _id: { $in: r.children.map((r) => r._id) } }, { fields: { children: 1 } } @@ -788,7 +788,7 @@ Object.assign(Roles, { selector.scope = options.scope } - await Meteor.roleAssignment.removeAsync(selector) + await RoleAssignmentCollection.removeAsync(selector) }, /** @@ -861,7 +861,7 @@ Object.assign(Roles, { const res = await asyncSome(roles, async (roleName) => { selector['inheritedRoles._id'] = roleName const out = - (await Meteor.roleAssignment + (await RoleAssignmentCollection .find(selector, { limit: 1 }) .countAsync()) > 0 return out @@ -935,7 +935,7 @@ Object.assign(Roles, { delete filter.fields } - const roles = await Meteor.roleAssignment.find(selector, filter).fetchAsync() + const roles = await RoleAssignmentCollection.find(selector, filter).fetchAsync() if (options.fullObjects) { return roles @@ -960,14 +960,14 @@ Object.assign(Roles, { * * @method getAllRoles * @param {Object} [queryOptions] Options which are passed directly - * through to `Meteor.roles.find(query, options)`. + * through to `RolesCollection.find(query, options)`. * @return {Cursor} Cursor of existing roles. * @static */ getAllRoles: function (queryOptions) { queryOptions = queryOptions || { sort: { _id: 1 } } - return Meteor.roles.find({}, queryOptions) + return RolesCollection.find({}, queryOptions) }, /** @@ -1020,7 +1020,7 @@ Object.assign(Roles, { * roles will also be checked * - `anyScope`: if set, role can be in any scope (`scope` option is ignored) * - `queryOptions`: options which are passed directly - * through to `Meteor.roleAssignment.find(query, options)` + * through to `RoleAssignmentCollection.find(query, options)` * Alternatively, it can be a scope name string. * @return {Cursor} Cursor of user assignments for roles. @@ -1053,7 +1053,7 @@ Object.assign(Roles, { * * Alternatively, it can be a scope name string. * @param {Object} [filter] Options which are passed directly - * through to `Meteor.roleAssignment.find(query, options)` + * through to `RoleAssignmentCollection.find(query, options)` * @return {Object} Cursor to the assignment documents * @private * @static @@ -1093,7 +1093,7 @@ Object.assign(Roles, { } } - return Meteor.roleAssignment.find(selector, filter) + return RoleAssignmentCollection.find(selector, filter) }, /** @@ -1149,7 +1149,7 @@ Object.assign(Roles, { } const scopes = ( - await Meteor.roleAssignment + await RoleAssignmentCollection .find(selector, { fields: { scope: 1 } }) .fetchAsync() ).map((obi) => obi.scope) @@ -1177,7 +1177,7 @@ Object.assign(Roles, { if (oldName === newName) return do { - count = await Meteor.roleAssignment.updateAsync( + count = await RoleAssignmentCollection.updateAsync( { scope: oldName }, @@ -1204,7 +1204,7 @@ Object.assign(Roles, { removeScopeAsync: async function (name) { Roles._checkScopeName(name) - await Meteor.roleAssignment.removeAsync({ scope: name }) + await RoleAssignmentCollection.removeAsync({ scope: name }) }, /** @@ -1256,7 +1256,7 @@ Object.assign(Roles, { return true } - const role = await Meteor.roles.findOneAsync({ _id: roleName }) + const role = await RolesCollection.findOneAsync({ _id: roleName }) // This should not happen, but this is a problem to address at some other time. if (!role) continue @@ -1309,7 +1309,7 @@ Object.assign(Roles, { /** * Throw an exception if `scopeName` is an invalid scope name. * - * @method _checkRoleName + * @method _checkScopeName * @param {String} scopeName A scope name to match against. * @private * @static diff --git a/roles/roles_server.js b/roles/roles_server.js index 0bf50828..90c85785 100644 --- a/roles/roles_server.js +++ b/roles/roles_server.js @@ -1,7 +1,8 @@ import { Meteor } from 'meteor/meteor' +import { RolesCollection, RoleAssignmentCollection } from './roles_common_async' -const indexFnAssignment = Meteor.roleAssignment.createIndexAsync.bind(Meteor.roleAssignment) -const indexFnRoles = Meteor.roles.createIndexAsync.bind(Meteor.roles) +const indexFnAssignment = RoleAssignmentCollection.createIndexAsync.bind(RoleAssignmentCollection) +const indexFnRoles = RolesCollection.createIndexAsync.bind(RolesCollection) const indexes = [ { 'user._id': 1, 'inheritedRoles._id': 1, scope: 1 }, From bd27146906a827ca673190cf1b2cae0d96ac6dfd Mon Sep 17 00:00:00 2001 From: Jan Dvorak Date: Sat, 8 Jun 2024 08:24:56 +0200 Subject: [PATCH 23/45] Update Blaze dependency & Published alanning:roles@4.0.0-alpha.4 --- .versions | 22 +++++++++++----------- package-lock.json | 5 ++++- package.js | 8 ++++---- 3 files changed, 19 insertions(+), 16 deletions(-) diff --git a/.versions b/.versions index 2a70a936..ae820416 100644 --- a/.versions +++ b/.versions @@ -1,5 +1,5 @@ -accounts-base@2.2.10 -alanning:roles@4.0.0-alpha.3 +accounts-base@2.2.11 +alanning:roles@4.0.0-alpha.4 allow-deny@1.1.1 babel-compiler@7.10.5 babel-runtime@1.5.1 @@ -7,12 +7,12 @@ base64@1.0.12 binary-heap@1.0.11 boilerplate-generator@1.7.2 callback-hook@1.5.1 -check@1.3.2 +check@1.4.1 ddp@1.4.1 -ddp-client@2.6.1 -ddp-common@1.4.0 +ddp-client@2.6.2 +ddp-common@1.4.1 ddp-rate-limiter@1.2.1 -ddp-server@2.7.0 +ddp-server@2.7.1 diff-sequence@1.1.2 dynamic-import@0.7.3 ecmascript@0.16.8 @@ -27,18 +27,18 @@ id-map@1.1.1 inter-process-messaging@0.1.1 lmieulet:meteor-coverage@4.1.0 lmieulet:meteor-legacy-coverage@0.1.0 -local-test:alanning:roles@4.0.0-alpha.3 +local-test:alanning:roles@4.0.0-alpha.4 localstorage@1.2.0 -logging@1.3.3 +logging@1.3.4 meteor@1.11.5 meteortesting:browser-tests@1.4.2 meteortesting:mocha@2.1.0 meteortesting:mocha-core@8.0.1 -minimongo@1.9.3 +minimongo@1.9.4 modern-browsers@0.1.10 modules@0.20.0 modules-runtime@0.13.1 -mongo@1.16.8 +mongo@1.16.10 mongo-decimal@0.1.3 mongo-dev-server@1.1.0 mongo-id@1.0.8 @@ -55,7 +55,7 @@ routepolicy@1.1.1 socket-stream-client@0.5.2 tracker@1.3.3 typescript@4.9.5 -underscore@1.6.0 +underscore@1.6.1 url@1.3.2 webapp@1.13.8 webapp-hashing@1.1.1 diff --git a/package-lock.json b/package-lock.json index 48e341a0..9af4873b 100644 --- a/package-lock.json +++ b/package-lock.json @@ -1,3 +1,6 @@ { - "lockfileVersion": 1 + "name": "meteor-roles", + "lockfileVersion": 3, + "requires": true, + "packages": {} } diff --git a/package.js b/package.js index c45d403c..33424f79 100644 --- a/package.js +++ b/package.js @@ -2,13 +2,13 @@ Package.describe({ summary: 'Authorization package for Meteor', - version: '4.0.0-alpha.3', + version: '4.0.0-alpha.4', git: 'https://github.com/Meteor-Community-Packages/meteor-roles.git', name: 'alanning:roles' }) Package.onUse(function (api) { - api.versionsFrom(['2.8.1', '3.0-rc.0']) + api.versionsFrom(['2.8.1', '3.0-rc.2']) const both = ['client', 'server'] @@ -23,7 +23,7 @@ Package.onUse(function (api) { api.use('zodern:types@1.0.13') - api.use(['blaze@2.9.0'], 'client', { weak: true }) + api.use(['blaze@2.9.0 || 3.0.0-rc300.2'], 'client', { weak: true }) api.export(['Roles', 'RolesCollection', 'RoleAssignmentCollection']) @@ -45,7 +45,7 @@ Package.onTest(function (api) { 'meteortesting:mocha@2.1.0' ]) - api.versionsFrom('2.8.1') + api.versionsFrom(['2.8.1', '3.0-rc.2']) const both = ['client', 'server'] From 560a265f767dac73e2da660c800566575db4e072 Mon Sep 17 00:00:00 2001 From: Jan Dvorak Date: Tue, 16 Jul 2024 09:06:39 +0200 Subject: [PATCH 24/45] Update for Meteor 3 release Still waiting for release of Blaze 3 before final release --- History.md | 1 + package.js | 6 +++--- 2 files changed, 4 insertions(+), 3 deletions(-) diff --git a/History.md b/History.md index b0c5c9ab..e32c4458 100644 --- a/History.md +++ b/History.md @@ -6,6 +6,7 @@ * BREAKING: Migration functions for past versions are no longer available * UI Helpers now use `console.debug` for debugging messages * `RolesCollection` and `RoleAssignmentsCollection` can now be exported in addition to being accessed via `Meteor.roles` and `Meteor.roleAssignment` +* Support for Meteor 3 ## v3.6.3 diff --git a/package.js b/package.js index 33424f79..2d37588a 100644 --- a/package.js +++ b/package.js @@ -2,13 +2,13 @@ Package.describe({ summary: 'Authorization package for Meteor', - version: '4.0.0-alpha.4', + version: '4.0.0-rc.1', git: 'https://github.com/Meteor-Community-Packages/meteor-roles.git', name: 'alanning:roles' }) Package.onUse(function (api) { - api.versionsFrom(['2.8.1', '3.0-rc.2']) + api.versionsFrom(['2.8.1', '3.0']) const both = ['client', 'server'] @@ -45,7 +45,7 @@ Package.onTest(function (api) { 'meteortesting:mocha@2.1.0' ]) - api.versionsFrom(['2.8.1', '3.0-rc.2']) + api.versionsFrom(['2.8.1', '3.0']) const both = ['client', 'server'] From c5d049cd060a4211e2c2536c70016cf43d3b1dc5 Mon Sep 17 00:00:00 2001 From: Jan Dvorak Date: Mon, 22 Jul 2024 15:29:43 +0200 Subject: [PATCH 25/45] Published alanning:roles@4.0.0-rc.2 --- .versions | 4 ++-- package.js | 2 +- 2 files changed, 3 insertions(+), 3 deletions(-) diff --git a/.versions b/.versions index ae820416..bf9c9e5c 100644 --- a/.versions +++ b/.versions @@ -1,5 +1,5 @@ accounts-base@2.2.11 -alanning:roles@4.0.0-alpha.4 +alanning:roles@4.0.0-rc.2 allow-deny@1.1.1 babel-compiler@7.10.5 babel-runtime@1.5.1 @@ -27,7 +27,7 @@ id-map@1.1.1 inter-process-messaging@0.1.1 lmieulet:meteor-coverage@4.1.0 lmieulet:meteor-legacy-coverage@0.1.0 -local-test:alanning:roles@4.0.0-alpha.4 +local-test:alanning:roles@4.0.0-rc.2 localstorage@1.2.0 logging@1.3.4 meteor@1.11.5 diff --git a/package.js b/package.js index 2d37588a..27511558 100644 --- a/package.js +++ b/package.js @@ -2,7 +2,7 @@ Package.describe({ summary: 'Authorization package for Meteor', - version: '4.0.0-rc.1', + version: '4.0.0-rc.2', git: 'https://github.com/Meteor-Community-Packages/meteor-roles.git', name: 'alanning:roles' }) From d8aea7c6eb78c56bda06ea7f4e92d51779c81061 Mon Sep 17 00:00:00 2001 From: Jan Dvorak Date: Mon, 22 Jul 2024 15:30:30 +0200 Subject: [PATCH 26/45] Update to final Blaze 3 release --- package.js | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/package.js b/package.js index 27511558..b9c3e6de 100644 --- a/package.js +++ b/package.js @@ -23,7 +23,7 @@ Package.onUse(function (api) { api.use('zodern:types@1.0.13') - api.use(['blaze@2.9.0 || 3.0.0-rc300.2'], 'client', { weak: true }) + api.use(['blaze@2.9.0 || 3.0.0'], 'client', { weak: true }) api.export(['Roles', 'RolesCollection', 'RoleAssignmentCollection']) From 675c0b314f8e4ebfb05e957c3bc195355818dcd2 Mon Sep 17 00:00:00 2001 From: Jan Dvorak Date: Mon, 22 Jul 2024 15:41:54 +0200 Subject: [PATCH 27/45] Lint fix --- roles/roles_client.js | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/roles/roles_client.js b/roles/roles_client.js index abe4de70..b6988ea8 100644 --- a/roles/roles_client.js +++ b/roles/roles_client.js @@ -181,7 +181,7 @@ Object.assign(Roles, { }, { multi: true }) } while (count > 0) - RolesCollection.remove({ _id: oldName }) + RolesCollection.remove({ _id: oldName }) }, /** From 4bb968446405c2d17bcd69e6350c8b478c8b8dab Mon Sep 17 00:00:00 2001 From: Jan Dvorak Date: Mon, 22 Jul 2024 15:42:06 +0200 Subject: [PATCH 28/45] Update test suite versions --- .github/workflows/testsuite.yml | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/.github/workflows/testsuite.yml b/.github/workflows/testsuite.yml index 393f8e60..3bee1b70 100644 --- a/.github/workflows/testsuite.yml +++ b/.github/workflows/testsuite.yml @@ -37,8 +37,8 @@ jobs: matrix: meteorRelease: - '2.8.1' - - '2.15' - - '3.0-rc.0' + - '2.16' + - '3.0' # Latest version steps: - name: Checkout code From 75355be0009300cdc40f03600a53987aeccd0099 Mon Sep 17 00:00:00 2001 From: Jan Dvorak Date: Mon, 22 Jul 2024 18:02:55 +0200 Subject: [PATCH 29/45] Replace countAsync with countDocuments in userIsInRoleAsync --- roles/roles_common_async.js | 4 +--- 1 file changed, 1 insertion(+), 3 deletions(-) diff --git a/roles/roles_common_async.js b/roles/roles_common_async.js index c63c91ef..1c8f3014 100644 --- a/roles/roles_common_async.js +++ b/roles/roles_common_async.js @@ -861,9 +861,7 @@ Object.assign(Roles, { const res = await asyncSome(roles, async (roleName) => { selector['inheritedRoles._id'] = roleName const out = - (await RoleAssignmentCollection - .find(selector, { limit: 1 }) - .countAsync()) > 0 + (await RoleAssignmentCollection.countDocuments(selector, { limit: 1 })) > 0 return out }) From e355dd03d7f5894da1fd5831282043fe52bb3c5f Mon Sep 17 00:00:00 2001 From: Jan Dvorak Date: Thu, 29 Aug 2024 11:35:30 +0200 Subject: [PATCH 30/45] Small modernization --- roles/roles_common_async.js | 8 ++++---- roles/roles_server.js | 4 +++- 2 files changed, 7 insertions(+), 5 deletions(-) diff --git a/roles/roles_common_async.js b/roles/roles_common_async.js index 1c8f3014..c14bdf8a 100644 --- a/roles/roles_common_async.js +++ b/roles/roles_common_async.js @@ -290,13 +290,13 @@ Object.assign(Roles, { const role = await RolesCollection.findOneAsync({ _id: roleName }) if (!role) { - throw new Error("Role '" + roleName + "' does not exist.") + throw new Error(`Role '${roleName}' does not exist.`) } // detect cycles if ((await Roles._getInheritedRoleNamesAsync(role)).includes(parentName)) { throw new Error( - "Roles '" + roleName + "' and '" + parentName + "' would form a cycle." + `Roles '${roleName}' and '${parentName}' would form a cycle.` ) } @@ -1219,7 +1219,7 @@ Object.assign(Roles, { typeof roleName !== 'string' || roleName.trim() !== roleName ) { - throw new Error("Invalid role name '" + roleName + "'.") + throw new Error(`Invalid role name '${roleName}'.`) } }, @@ -1320,7 +1320,7 @@ Object.assign(Roles, { typeof scopeName !== 'string' || scopeName.trim() !== scopeName ) { - throw new Error("Invalid scope name '" + scopeName + "'.") + throw new Error(`Invalid scope name '${scopeName}'.`) } } }) diff --git a/roles/roles_server.js b/roles/roles_server.js index 90c85785..e06e2327 100644 --- a/roles/roles_server.js +++ b/roles/roles_server.js @@ -11,7 +11,9 @@ const indexes = [ { scope: 1, 'user._id': 1, 'inheritedRoles._id': 1 }, // Adding userId and roleId might speed up other queries depending on the first index { 'inheritedRoles._id': 1 } ] -indexes.forEach(index => indexFnAssignment(index)) +for (const index of indexes) { + indexFnAssignment(index) +} indexFnRoles({ 'children._id': 1 }) /* From 995467bd6f724aa34bcc8b8d1e6efcbcd8c52476 Mon Sep 17 00:00:00 2001 From: Jan Dvorak Date: Thu, 29 Aug 2024 12:24:59 +0200 Subject: [PATCH 31/45] Revert to using Meteor for collection access --- roles/roles_client.js | 76 +++++++++++++++---------------- roles/roles_common_async.js | 90 ++++++++++++++++++------------------- roles/tests/client.js | 5 ++- 3 files changed, 85 insertions(+), 86 deletions(-) diff --git a/roles/roles_client.js b/roles/roles_client.js index b6988ea8..bc04a237 100644 --- a/roles/roles_client.js +++ b/roles/roles_client.js @@ -1,8 +1,6 @@ /* global Roles */ import { Meteor } from 'meteor/meteor' -import { RolesCollection, RoleAssignmentCollection } from './roles_common_async' - /** * Provides functions related to user authorization. Compatible with built-in Meteor accounts packages. * @@ -65,7 +63,7 @@ Object.assign(Roles, { unlessExists: false }, options) - const result = RolesCollection.upsert({ _id: roleName }, { $setOnInsert: { children: [] } }) + const result = Meteor.roles.upsert({ _id: roleName }, { $setOnInsert: { children: [] } }) if (!result.insertedId) { if (options.unlessExists) return null @@ -91,16 +89,16 @@ Object.assign(Roles, { Roles._checkRoleName(roleName) // Remove all assignments - RoleAssignmentCollection.remove({ + Meteor.roleAssignment.remove({ 'role._id': roleName }) do { // For all roles who have it as a dependency ... - roles = Roles._getParentRoleNames(RolesCollection.findOne({ _id: roleName })) + roles = Roles._getParentRoleNames(Meteor.roles.findOne({ _id: roleName })) - RolesCollection.find({ _id: { $in: roles } }).fetch().forEach(r => { - RolesCollection.update({ + Meteor.roles.find({ _id: { $in: roles } }).fetch().forEach(r => { + Meteor.roles.update({ _id: r._id }, { $pull: { @@ -110,8 +108,8 @@ Object.assign(Roles, { } }) - inheritedRoles = Roles._getInheritedRoleNames(RolesCollection.findOne({ _id: r._id })) - RoleAssignmentCollection.update({ + inheritedRoles = Roles._getInheritedRoleNames(Meteor.roles.findOne({ _id: r._id })) + Meteor.roleAssignment.update({ 'role._id': r._id }, { $set: { @@ -122,7 +120,7 @@ Object.assign(Roles, { } while (roles.length > 0) // And finally remove the role itself - RolesCollection.remove({ _id: roleName }) + Meteor.roles.remove({ _id: roleName }) }, /** @@ -141,7 +139,7 @@ Object.assign(Roles, { if (oldName === newName) return - const role = RolesCollection.findOne({ _id: oldName }) + const role = Meteor.roles.findOne({ _id: oldName }) if (!role) { throw new Error('Role \'' + oldName + '\' does not exist.') @@ -149,10 +147,10 @@ Object.assign(Roles, { role._id = newName - RolesCollection.insert(role) + Meteor.roles.insert(role) do { - count = RoleAssignmentCollection.update({ + count = Meteor.roleAssignment.update({ 'role._id': oldName }, { $set: { @@ -162,7 +160,7 @@ Object.assign(Roles, { } while (count > 0) do { - count = RoleAssignmentCollection.update({ + count = Meteor.roleAssignment.update({ 'inheritedRoles._id': oldName }, { $set: { @@ -172,7 +170,7 @@ Object.assign(Roles, { } while (count > 0) do { - count = RolesCollection.update({ + count = Meteor.roles.update({ 'children._id': oldName }, { $set: { @@ -181,7 +179,7 @@ Object.assign(Roles, { }, { multi: true }) } while (count > 0) - RolesCollection.remove({ _id: oldName }) + Meteor.roles.remove({ _id: oldName }) }, /** @@ -216,7 +214,7 @@ Object.assign(Roles, { Roles._checkRoleName(parentName) // query to get role's children - const role = RolesCollection.findOne({ _id: roleName }) + const role = Meteor.roles.findOne({ _id: roleName }) if (!role) { throw new Error('Role \'' + roleName + '\' does not exist.') @@ -227,7 +225,7 @@ Object.assign(Roles, { throw new Error('Roles \'' + roleName + '\' and \'' + parentName + '\' would form a cycle.') } - const count = RolesCollection.update({ + const count = Meteor.roles.update({ _id: parentName, 'children._id': { $ne: role._id @@ -244,7 +242,7 @@ Object.assign(Roles, { // already a subrole; in any case we do not have anything more to do if (!count) return - RoleAssignmentCollection.update({ + Meteor.roleAssignment.update({ 'inheritedRoles._id': parentName }, { $push: { @@ -286,13 +284,13 @@ Object.assign(Roles, { // check for role existence // this would not really be needed, but we are trying to match addRolesToParent - const role = RolesCollection.findOne({ _id: roleName }, { fields: { _id: 1 } }) + const role = Meteor.roles.findOne({ _id: roleName }, { fields: { _id: 1 } }) if (!role) { throw new Error('Role \'' + roleName + '\' does not exist.') } - const count = RolesCollection.update({ + const count = Meteor.roles.update({ _id: parentName }, { $pull: { @@ -307,11 +305,11 @@ Object.assign(Roles, { if (!count) return // For all roles who have had it as a dependency ... - const roles = [...Roles._getParentRoleNames(RolesCollection.findOne({ _id: parentName })), parentName] + const roles = [...Roles._getParentRoleNames(Meteor.roles.findOne({ _id: parentName })), parentName] - RolesCollection.find({ _id: { $in: roles } }).fetch().forEach(r => { - const inheritedRoles = Roles._getInheritedRoleNames(RolesCollection.findOne({ _id: r._id })) - RoleAssignmentCollection.update({ + Meteor.roles.find({ _id: { $in: roles } }).fetch().forEach(r => { + const inheritedRoles = Roles._getInheritedRoleNames(Meteor.roles.findOne({ _id: r._id })) + Meteor.roleAssignment.update({ 'role._id': r._id, 'inheritedRoles._id': role._id }, { @@ -427,7 +425,7 @@ Object.assign(Roles, { selector.scope = options.scope } - RoleAssignmentCollection.remove(selector) + Meteor.roleAssignment.remove(selector) // and then add all roles.forEach(function (role) { @@ -456,7 +454,7 @@ Object.assign(Roles, { return } - const role = RolesCollection.findOne({ _id: roleName }, { fields: { children: 1 } }) + const role = Meteor.roles.findOne({ _id: roleName }, { fields: { children: 1 } }) if (!role) { if (options.ifExists) { @@ -467,7 +465,7 @@ Object.assign(Roles, { } // This might create duplicates, because we don't have a unique index, but that's all right. In case there are two, withdrawing the role will effectively kill them both. - const res = RoleAssignmentCollection.upsert({ + const res = Meteor.roleAssignment.upsert({ 'user._id': userId, 'role._id': roleName, scope: options.scope @@ -480,7 +478,7 @@ Object.assign(Roles, { }) if (res.insertedId) { - RoleAssignmentCollection.update({ _id: res.insertedId }, { + Meteor.roleAssignment.update({ _id: res.insertedId }, { $set: { inheritedRoles: [roleName, ...Roles._getInheritedRoleNames(role)].map(r => ({ _id: r })) } @@ -509,7 +507,7 @@ Object.assign(Roles, { const parentRoles = new Set([role._id]) parentRoles.forEach(roleName => { - RolesCollection.find({ 'children._id': roleName }).fetch().forEach(parentRole => { + Meteor.roles.find({ 'children._id': roleName }).fetch().forEach(parentRole => { parentRoles.add(parentRole._id) }) }) @@ -535,7 +533,7 @@ Object.assign(Roles, { const nestedRoles = new Set([role]) nestedRoles.forEach(r => { - const roles = RolesCollection.find({ _id: { $in: r.children.map(r => r._id) } }, { fields: { children: 1 } }).fetch() + const roles = Meteor.roles.find({ _id: { $in: r.children.map(r => r._id) } }, { fields: { children: 1 } }).fetch() roles.forEach(r2 => { inheritedRoles.add(r2._id) @@ -619,7 +617,7 @@ Object.assign(Roles, { selector.scope = options.scope } - RoleAssignmentCollection.remove(selector) + Meteor.roleAssignment.remove(selector) }, /** @@ -686,7 +684,7 @@ Object.assign(Roles, { return roles.some((roleName) => { selector['inheritedRoles._id'] = roleName - return RoleAssignmentCollection.find(selector, { limit: 1 }).count() > 0 + return Meteor.roleAssignment.find(selector, { limit: 1 }).count() > 0 }) }, @@ -750,7 +748,7 @@ Object.assign(Roles, { delete filter.fields } - const roles = RoleAssignmentCollection.find(selector, filter).fetch() + const roles = Meteor.roleAssignment.find(selector, filter).fetch() if (options.fullObjects) { return roles @@ -778,7 +776,7 @@ Object.assign(Roles, { getAllRoles: function (queryOptions) { queryOptions = queryOptions || { sort: { _id: 1 } } - return RolesCollection.find({}, queryOptions) + return Meteor.roles.find({}, queryOptions) }, /** @@ -888,7 +886,7 @@ Object.assign(Roles, { } } - return RoleAssignmentCollection.find(selector, filter) + return Meteor.roleAssignment.find(selector, filter) }, /** @@ -939,7 +937,7 @@ Object.assign(Roles, { selector['inheritedRoles._id'] = { $in: roles } } - const scopes = RoleAssignmentCollection.find(selector, { fields: { scope: 1 } }).fetch().map(obi => obi.scope) + const scopes = Meteor.roleAssignment.find(selector, { fields: { scope: 1 } }).fetch().map(obi => obi.scope) return [...new Set(scopes)] }, @@ -963,7 +961,7 @@ Object.assign(Roles, { if (oldName === newName) return do { - count = RoleAssignmentCollection.update({ + count = Meteor.roleAssignment.update({ scope: oldName }, { $set: { @@ -985,7 +983,7 @@ Object.assign(Roles, { removeScope: function (name) { Roles._checkScopeName(name) - RoleAssignmentCollection.remove({ scope: name }) + Meteor.roleAssignment.remove({ scope: name }) }, /** diff --git a/roles/roles_common_async.js b/roles/roles_common_async.js index c14bdf8a..45337feb 100644 --- a/roles/roles_common_async.js +++ b/roles/roles_common_async.js @@ -92,16 +92,16 @@ Object.assign(Roles, { let insertedId = null - const existingRole = await RolesCollection.findOneAsync({ _id: roleName }) + const existingRole = await Meteor.roles.findOneAsync({ _id: roleName }) if (existingRole) { - await RolesCollection.updateAsync( + await Meteor.roles.updateAsync( { _id: roleName }, { $setOnInsert: { children: [] } } ) return null } else { - insertedId = await RolesCollection.insertAsync({ + insertedId = await Meteor.roles.insertAsync({ _id: roleName, children: [] }) @@ -132,20 +132,20 @@ Object.assign(Roles, { Roles._checkRoleName(roleName) // Remove all assignments - await RoleAssignmentCollection.removeAsync({ + await Meteor.roleAssignment.removeAsync({ 'role._id': roleName }) do { // For all roles who have it as a dependency ... roles = await Roles._getParentRoleNamesAsync( - await RolesCollection.findOneAsync({ _id: roleName }) + await Meteor.roles.findOneAsync({ _id: roleName }) ) - for (const r of await RolesCollection + for (const r of await Meteor.roles .find({ _id: { $in: roles } }) .fetchAsync()) { - await RolesCollection.updateAsync( + await Meteor.roles.updateAsync( { _id: r._id }, @@ -159,9 +159,9 @@ Object.assign(Roles, { ) inheritedRoles = await Roles._getInheritedRoleNamesAsync( - await RolesCollection.findOneAsync({ _id: r._id }) + await Meteor.roles.findOneAsync({ _id: r._id }) ) - await RoleAssignmentCollection.updateAsync( + await Meteor.roleAssignment.updateAsync( { 'role._id': r._id }, @@ -178,7 +178,7 @@ Object.assign(Roles, { } while (roles.length > 0) // And finally remove the role itself - await RolesCollection.removeAsync({ _id: roleName }) + await Meteor.roles.removeAsync({ _id: roleName }) }, /** @@ -198,7 +198,7 @@ Object.assign(Roles, { if (oldName === newName) return - const role = await RolesCollection.findOneAsync({ _id: oldName }) + const role = await Meteor.roles.findOneAsync({ _id: oldName }) if (!role) { throw new Error("Role '" + oldName + "' does not exist.") @@ -206,10 +206,10 @@ Object.assign(Roles, { role._id = newName - await RolesCollection.insertAsync(role) + await Meteor.roles.insertAsync(role) do { - count = await RoleAssignmentCollection.updateAsync( + count = await Meteor.roleAssignment.updateAsync( { 'role._id': oldName }, @@ -223,7 +223,7 @@ Object.assign(Roles, { } while (count > 0) do { - count = await RoleAssignmentCollection.updateAsync( + count = await Meteor.roleAssignment.updateAsync( { 'inheritedRoles._id': oldName }, @@ -237,7 +237,7 @@ Object.assign(Roles, { } while (count > 0) do { - count = await RolesCollection.updateAsync( + count = await Meteor.roles.updateAsync( { 'children._id': oldName }, @@ -250,7 +250,7 @@ Object.assign(Roles, { ) } while (count > 0) - await RolesCollection.removeAsync({ _id: oldName }) + await Meteor.roles.removeAsync({ _id: oldName }) }, /** @@ -287,7 +287,7 @@ Object.assign(Roles, { Roles._checkRoleName(parentName) // query to get role's children - const role = await RolesCollection.findOneAsync({ _id: roleName }) + const role = await Meteor.roles.findOneAsync({ _id: roleName }) if (!role) { throw new Error(`Role '${roleName}' does not exist.`) @@ -300,7 +300,7 @@ Object.assign(Roles, { ) } - const count = await RolesCollection.updateAsync( + const count = await Meteor.roles.updateAsync( { _id: parentName, 'children._id': { @@ -320,7 +320,7 @@ Object.assign(Roles, { // already a sub-role; in any case we do not have anything more to do if (!count) return - await RoleAssignmentCollection.updateAsync( + await Meteor.roleAssignment.updateAsync( { 'inheritedRoles._id': parentName }, @@ -373,16 +373,16 @@ Object.assign(Roles, { // check for role existence // this would not really be needed, but we are trying to match addRolesToParent - const role = await RolesCollection.findOneAsync( + const role = await Meteor.roles.findOneAsync( { _id: roleName }, { fields: { _id: 1 } } ) if (!role) { - throw new Error("Role '" + roleName + "' does not exist.") + throw new Error(`Role '${roleName}' does not exist.`) } - const count = await RolesCollection.updateAsync( + const count = await Meteor.roles.updateAsync( { _id: parentName }, @@ -402,18 +402,18 @@ Object.assign(Roles, { // For all roles who have had it as a dependency ... const roles = [ ...(await Roles._getParentRoleNamesAsync( - await RolesCollection.findOneAsync({ _id: parentName }) + await Meteor.roles.findOneAsync({ _id: parentName }) )), parentName ] - for (const r of await RolesCollection + for (const r of await Meteor.roles .find({ _id: { $in: roles } }) .fetchAsync()) { const inheritedRoles = await Roles._getInheritedRoleNamesAsync( - await RolesCollection.findOneAsync({ _id: r._id }) + await Meteor.roles.findOneAsync({ _id: r._id }) ) - await RoleAssignmentCollection.updateAsync( + await Meteor.roleAssignment.updateAsync( { 'role._id': r._id, 'inheritedRoles._id': role._id @@ -543,7 +543,7 @@ Object.assign(Roles, { selector.scope = options.scope } - await RoleAssignmentCollection.removeAsync(selector) + await Meteor.roleAssignment.removeAsync(selector) // and then add all for (const role of roles) { @@ -573,7 +573,7 @@ Object.assign(Roles, { return } - const role = await RolesCollection.findOneAsync( + const role = await Meteor.roles.findOneAsync( { _id: roleName }, { fields: { children: 1 } } ) @@ -602,7 +602,7 @@ Object.assign(Roles, { }, } ); */ - const existingAssignment = await RoleAssignmentCollection.findOneAsync({ + const existingAssignment = await Meteor.roleAssignment.findOneAsync({ 'user._id': userId, 'role._id': roleName, scope: options.scope @@ -611,7 +611,7 @@ Object.assign(Roles, { let insertedId let res if (existingAssignment) { - await RoleAssignmentCollection.updateAsync(existingAssignment._id, { + await Meteor.roleAssignment.updateAsync(existingAssignment._id, { $set: { user: { _id: userId }, role: { _id: roleName }, @@ -619,9 +619,9 @@ Object.assign(Roles, { } }) - res = await RoleAssignmentCollection.findOneAsync(existingAssignment._id) + res = await Meteor.roleAssignment.findOneAsync(existingAssignment._id) } else { - insertedId = await RoleAssignmentCollection.insertAsync({ + insertedId = await Meteor.roleAssignment.insertAsync({ user: { _id: userId }, role: { _id: roleName }, scope: options.scope @@ -629,7 +629,7 @@ Object.assign(Roles, { } if (insertedId) { - await RoleAssignmentCollection.updateAsync( + await Meteor.roleAssignment.updateAsync( { _id: insertedId }, { $set: { @@ -641,7 +641,7 @@ Object.assign(Roles, { } ) - res = await RoleAssignmentCollection.findOneAsync({ _id: insertedId }) + res = await Meteor.roleAssignment.findOneAsync({ _id: insertedId }) } res.insertedId = insertedId // For backward compatibility @@ -668,7 +668,7 @@ Object.assign(Roles, { const parentRoles = new Set([role._id]) for (const roleName of parentRoles) { - for (const parentRole of await RolesCollection + for (const parentRole of await Meteor.roles .find({ 'children._id': roleName }) .fetchAsync()) { parentRoles.add(parentRole._id) @@ -697,7 +697,7 @@ Object.assign(Roles, { const nestedRoles = new Set([role]) for (const r of nestedRoles) { - const roles = await RolesCollection + const roles = await Meteor.roles .find( { _id: { $in: r.children.map((r) => r._id) } }, { fields: { children: 1 } } @@ -788,7 +788,7 @@ Object.assign(Roles, { selector.scope = options.scope } - await RoleAssignmentCollection.removeAsync(selector) + await Meteor.roleAssignment.removeAsync(selector) }, /** @@ -861,7 +861,7 @@ Object.assign(Roles, { const res = await asyncSome(roles, async (roleName) => { selector['inheritedRoles._id'] = roleName const out = - (await RoleAssignmentCollection.countDocuments(selector, { limit: 1 })) > 0 + (await Meteor.roleAssignment.countDocuments(selector, { limit: 1 })) > 0 return out }) @@ -933,7 +933,7 @@ Object.assign(Roles, { delete filter.fields } - const roles = await RoleAssignmentCollection.find(selector, filter).fetchAsync() + const roles = await Meteor.roleAssignment.find(selector, filter).fetchAsync() if (options.fullObjects) { return roles @@ -965,7 +965,7 @@ Object.assign(Roles, { getAllRoles: function (queryOptions) { queryOptions = queryOptions || { sort: { _id: 1 } } - return RolesCollection.find({}, queryOptions) + return Meteor.roles.find({}, queryOptions) }, /** @@ -1091,7 +1091,7 @@ Object.assign(Roles, { } } - return RoleAssignmentCollection.find(selector, filter) + return Meteor.roleAssignment.find(selector, filter) }, /** @@ -1147,7 +1147,7 @@ Object.assign(Roles, { } const scopes = ( - await RoleAssignmentCollection + await Meteor.roleAssignment .find(selector, { fields: { scope: 1 } }) .fetchAsync() ).map((obi) => obi.scope) @@ -1175,7 +1175,7 @@ Object.assign(Roles, { if (oldName === newName) return do { - count = await RoleAssignmentCollection.updateAsync( + count = await Meteor.roleAssignment.updateAsync( { scope: oldName }, @@ -1202,7 +1202,7 @@ Object.assign(Roles, { removeScopeAsync: async function (name) { Roles._checkScopeName(name) - await RoleAssignmentCollection.removeAsync({ scope: name }) + await Meteor.roleAssignment.removeAsync({ scope: name }) }, /** @@ -1254,7 +1254,7 @@ Object.assign(Roles, { return true } - const role = await RolesCollection.findOneAsync({ _id: roleName }) + const role = await Meteor.roles.findOneAsync({ _id: roleName }) // This should not happen, but this is a problem to address at some other time. if (!role) continue diff --git a/roles/tests/client.js b/roles/tests/client.js index 317feebc..d92d3a89 100644 --- a/roles/tests/client.js +++ b/roles/tests/client.js @@ -3,6 +3,7 @@ import { Meteor } from 'meteor/meteor' import { assert } from 'chai' +import { Roles } from 'meteor/alanning:roles' // To ensure that the files are loaded for coverage import '../roles_client' @@ -31,7 +32,7 @@ describe('roles', function () { const user = users[username] // test using user object rather than userId to avoid mocking - roles.forEach(function (role) { + for (const role of roles) { const expected = expectedRoles.includes(role) const msg = username + ' expected to have \'' + role + '\' permission but does not' const nmsg = username + ' had un-expected permission ' + role @@ -41,7 +42,7 @@ describe('roles', function () { } else { assert.isFalse(Roles.userIsInRole(user, role, scope), nmsg) } - }) + } } let meteorUserMethod From a2142fb5abef2c305012b710fa19b434e1420396 Mon Sep 17 00:00:00 2001 From: Jan Dvorak Date: Thu, 29 Aug 2024 12:26:33 +0200 Subject: [PATCH 32/45] Fix Standard lint issue --- roles/tests/client.js | 1 - 1 file changed, 1 deletion(-) diff --git a/roles/tests/client.js b/roles/tests/client.js index d92d3a89..b9be9492 100644 --- a/roles/tests/client.js +++ b/roles/tests/client.js @@ -3,7 +3,6 @@ import { Meteor } from 'meteor/meteor' import { assert } from 'chai' -import { Roles } from 'meteor/alanning:roles' // To ensure that the files are loaded for coverage import '../roles_client' From 4d6a80380e7618f79d91ccf94f0c35cf1ea46b18 Mon Sep 17 00:00:00 2001 From: Jan Dvorak Date: Thu, 29 Aug 2024 12:29:21 +0200 Subject: [PATCH 33/45] Update testapp to Meteor v2.16 --- testapp/.meteor/packages | 4 +- testapp/.meteor/release | 2 +- testapp/.meteor/versions | 18 +- testapp/package-lock.json | 1222 +++++++++++++++---------------------- testapp/package.json | 8 +- 5 files changed, 513 insertions(+), 741 deletions(-) diff --git a/testapp/.meteor/packages b/testapp/.meteor/packages index 0d165be5..68b097e1 100644 --- a/testapp/.meteor/packages +++ b/testapp/.meteor/packages @@ -4,7 +4,7 @@ # 'meteor add' and 'meteor remove' will edit this file for you, # but you can also edit it by hand. -meteor@1.11.4 # Shared foundation for all Meteor packages +meteor@1.11.5 # Shared foundation for all Meteor packages static-html@1.3.2 # Define static page content in .html files standard-minifier-css@1.9.2 # CSS minifier run for production mode standard-minifier-js@2.8.1 # JS minifier run for production mode @@ -12,7 +12,7 @@ es5-shim@4.8.0 # ECMAScript 5 compatibility for older browsers ecmascript@0.16.8 # Enable ECMAScript2015+ syntax in app code typescript@4.9.5 # Enable TypeScript syntax in .ts and .tsx modules shell-server@0.5.0 # Server-side component of the `meteor shell` command -webapp@1.13.6 # Serves a Meteor app over HTTP +webapp@1.13.8 # Serves a Meteor app over HTTP server-render@0.4.1 # Support for server-side rendering hot-module-replacement@0.5.3 # Rebuilds the client if there is a change on the client without restarting the server diff --git a/testapp/.meteor/release b/testapp/.meteor/release index c500c39d..5152abe9 100644 --- a/testapp/.meteor/release +++ b/testapp/.meteor/release @@ -1 +1 @@ -METEOR@2.14 +METEOR@2.16 diff --git a/testapp/.meteor/versions b/testapp/.meteor/versions index 00869796..3b0f13a4 100644 --- a/testapp/.meteor/versions +++ b/testapp/.meteor/versions @@ -7,11 +7,11 @@ boilerplate-generator@1.7.2 caching-compiler@1.2.2 caching-html-compiler@1.2.1 callback-hook@1.5.1 -check@1.3.2 +check@1.4.1 ddp@1.4.1 -ddp-client@2.6.1 -ddp-common@1.4.0 -ddp-server@2.7.0 +ddp-client@2.6.2 +ddp-common@1.4.1 +ddp-server@2.7.1 diff-sequence@1.1.2 dynamic-import@0.7.3 ecmascript@0.16.8 @@ -27,10 +27,10 @@ html-tools@1.1.3 htmljs@1.1.1 id-map@1.1.1 inter-process-messaging@0.1.1 -logging@1.3.3 -meteor@1.11.4 +logging@1.3.4 +meteor@1.11.5 minifier-css@1.6.4 -minifier-js@2.7.5 +minifier-js@2.8.0 modern-browsers@0.1.10 modules@0.20.0 modules-runtime@0.13.1 @@ -52,6 +52,6 @@ static-html@1.3.2 templating-tools@1.2.2 tracker@1.3.3 typescript@4.9.5 -underscore@1.0.13 -webapp@1.13.6 +underscore@1.6.1 +webapp@1.13.8 webapp-hashing@1.1.1 diff --git a/testapp/package-lock.json b/testapp/package-lock.json index 21bdd216..4788e733 100644 --- a/testapp/package-lock.json +++ b/testapp/package-lock.json @@ -10,315 +10,208 @@ "dev": true }, "@ampproject/remapping": { - "version": "2.2.1", - "resolved": "https://registry.npmjs.org/@ampproject/remapping/-/remapping-2.2.1.tgz", - "integrity": "sha512-lFMjJTrFL3j7L9yBxwYfCq2k6qqwHyzuUl/XBnif78PWTJYyL/dfowQHWE3sp6U6ZzqWiiIZnpTMO96zhkjwtg==", + "version": "2.3.0", + "resolved": "https://registry.npmjs.org/@ampproject/remapping/-/remapping-2.3.0.tgz", + "integrity": "sha512-30iZtAPgz+LTIYoeivqYo853f02jBYSd5uGnGpkFV0M3xOt9aN73erkgYAmZU43x4VfqcnLxW9Kpg3R5LC4YYw==", "dev": true, "requires": { - "@jridgewell/gen-mapping": "^0.3.0", - "@jridgewell/trace-mapping": "^0.3.9" + "@jridgewell/gen-mapping": "^0.3.5", + "@jridgewell/trace-mapping": "^0.3.24" } }, "@babel/code-frame": { - "version": "7.22.5", - "resolved": "https://registry.npmjs.org/@babel/code-frame/-/code-frame-7.22.5.tgz", - "integrity": "sha512-Xmwn266vad+6DAqEB2A6V/CcZVp62BbwVmcOJc2RPuwih1kw02TjQvWVWlcKGbBPd+8/0V5DEkOcizRGYsspYQ==", + "version": "7.24.7", + "resolved": "https://registry.npmjs.org/@babel/code-frame/-/code-frame-7.24.7.tgz", + "integrity": "sha512-BcYH1CVJBO9tvyIZ2jVeXgSIMvGZ2FDRvDdOIVQyuklNKSsx+eppDEBq/g47Ayw+RqNFE+URvOShmf+f/qwAlA==", "dev": true, "requires": { - "@babel/highlight": "^7.22.5" + "@babel/highlight": "^7.24.7", + "picocolors": "^1.0.0" } }, "@babel/compat-data": { - "version": "7.22.9", - "resolved": "https://registry.npmjs.org/@babel/compat-data/-/compat-data-7.22.9.tgz", - "integrity": "sha512-5UamI7xkUcJ3i9qVDS+KFDEK8/7oJ55/sJMB1Ge7IEapr7KfdfV/HErR+koZwOfd+SgtFKOKRhRakdg++DcJpQ==", + "version": "7.25.4", + "resolved": "https://registry.npmjs.org/@babel/compat-data/-/compat-data-7.25.4.tgz", + "integrity": "sha512-+LGRog6RAsCJrrrg/IO6LGmpphNe5DiK30dGjCoxxeGv49B10/3XYGxPsAwrDlMFcFEvdAUavDT8r9k/hSyQqQ==", "dev": true }, "@babel/core": { - "version": "7.22.9", - "resolved": "https://registry.npmjs.org/@babel/core/-/core-7.22.9.tgz", - "integrity": "sha512-G2EgeufBcYw27U4hhoIwFcgc1XU7TlXJ3mv04oOv1WCuo900U/anZSPzEqNjwdjgffkk2Gs0AN0dW1CKVLcG7w==", + "version": "7.25.2", + "resolved": "https://registry.npmjs.org/@babel/core/-/core-7.25.2.tgz", + "integrity": "sha512-BBt3opiCOxUr9euZ5/ro/Xv8/V7yJ5bjYMqG/C1YAo8MIKAnumZalCN+msbci3Pigy4lIQfPUpfMM27HMGaYEA==", "dev": true, "requires": { "@ampproject/remapping": "^2.2.0", - "@babel/code-frame": "^7.22.5", - "@babel/generator": "^7.22.9", - "@babel/helper-compilation-targets": "^7.22.9", - "@babel/helper-module-transforms": "^7.22.9", - "@babel/helpers": "^7.22.6", - "@babel/parser": "^7.22.7", - "@babel/template": "^7.22.5", - "@babel/traverse": "^7.22.8", - "@babel/types": "^7.22.5", - "convert-source-map": "^1.7.0", + "@babel/code-frame": "^7.24.7", + "@babel/generator": "^7.25.0", + "@babel/helper-compilation-targets": "^7.25.2", + "@babel/helper-module-transforms": "^7.25.2", + "@babel/helpers": "^7.25.0", + "@babel/parser": "^7.25.0", + "@babel/template": "^7.25.0", + "@babel/traverse": "^7.25.2", + "@babel/types": "^7.25.2", + "convert-source-map": "^2.0.0", "debug": "^4.1.0", "gensync": "^1.0.0-beta.2", - "json5": "^2.2.2", + "json5": "^2.2.3", "semver": "^6.3.1" } }, "@babel/generator": { - "version": "7.22.9", - "resolved": "https://registry.npmjs.org/@babel/generator/-/generator-7.22.9.tgz", - "integrity": "sha512-KtLMbmicyuK2Ak/FTCJVbDnkN1SlT8/kceFTiuDiiRUUSMnHMidxSCdG4ndkTOHHpoomWe/4xkvHkEOncwjYIw==", + "version": "7.25.6", + "resolved": "https://registry.npmjs.org/@babel/generator/-/generator-7.25.6.tgz", + "integrity": "sha512-VPC82gr1seXOpkjAAKoLhP50vx4vGNlF4msF64dSFq1P8RfB+QAuJWGHPXXPc8QyfVWwwB/TNNU4+ayZmHNbZw==", "dev": true, "requires": { - "@babel/types": "^7.22.5", - "@jridgewell/gen-mapping": "^0.3.2", - "@jridgewell/trace-mapping": "^0.3.17", + "@babel/types": "^7.25.6", + "@jridgewell/gen-mapping": "^0.3.5", + "@jridgewell/trace-mapping": "^0.3.25", "jsesc": "^2.5.1" } }, "@babel/helper-compilation-targets": { - "version": "7.22.9", - "resolved": "https://registry.npmjs.org/@babel/helper-compilation-targets/-/helper-compilation-targets-7.22.9.tgz", - "integrity": "sha512-7qYrNM6HjpnPHJbopxmb8hSPoZ0gsX8IvUS32JGVoy+pU9e5N0nLr1VjJoR6kA4d9dmGLxNYOjeB8sUDal2WMw==", + "version": "7.25.2", + "resolved": "https://registry.npmjs.org/@babel/helper-compilation-targets/-/helper-compilation-targets-7.25.2.tgz", + "integrity": "sha512-U2U5LsSaZ7TAt3cfaymQ8WHh0pxvdHoEk6HVpaexxixjyEquMh0L0YNJNM6CTGKMXV1iksi0iZkGw4AcFkPaaw==", "dev": true, "requires": { - "@babel/compat-data": "^7.22.9", - "@babel/helper-validator-option": "^7.22.5", - "browserslist": "^4.21.9", + "@babel/compat-data": "^7.25.2", + "@babel/helper-validator-option": "^7.24.8", + "browserslist": "^4.23.1", "lru-cache": "^5.1.1", "semver": "^6.3.1" } }, - "@babel/helper-environment-visitor": { - "version": "7.22.5", - "resolved": "https://registry.npmjs.org/@babel/helper-environment-visitor/-/helper-environment-visitor-7.22.5.tgz", - "integrity": "sha512-XGmhECfVA/5sAt+H+xpSg0mfrHq6FzNr9Oxh7PSEBBRUb/mL7Kz3NICXb194rCqAEdxkhPT1a88teizAFyvk8Q==", - "dev": true - }, - "@babel/helper-hoist-variables": { - "version": "7.22.5", - "resolved": "https://registry.npmjs.org/@babel/helper-hoist-variables/-/helper-hoist-variables-7.22.5.tgz", - "integrity": "sha512-wGjk9QZVzvknA6yKIUURb8zY3grXCcOZt+/7Wcy8O2uctxhplmUPkOdlgoNhmdVee2c92JXbf1xpMtVNbfoxRw==", - "dev": true, - "requires": { - "@babel/types": "^7.22.5" - } - }, "@babel/helper-module-imports": { - "version": "7.22.5", - "resolved": "https://registry.npmjs.org/@babel/helper-module-imports/-/helper-module-imports-7.22.5.tgz", - "integrity": "sha512-8Dl6+HD/cKifutF5qGd/8ZJi84QeAKh+CEe1sBzz8UayBBGg1dAIJrdHOcOM5b2MpzWL2yuotJTtGjETq0qjXg==", + "version": "7.24.7", + "resolved": "https://registry.npmjs.org/@babel/helper-module-imports/-/helper-module-imports-7.24.7.tgz", + "integrity": "sha512-8AyH3C+74cgCVVXow/myrynrAGv+nTVg5vKu2nZph9x7RcRwzmh0VFallJuFTZ9mx6u4eSdXZfcOzSqTUm0HCA==", "dev": true, "requires": { - "@babel/types": "^7.22.5" + "@babel/traverse": "^7.24.7", + "@babel/types": "^7.24.7" } }, "@babel/helper-module-transforms": { - "version": "7.22.9", - "resolved": "https://registry.npmjs.org/@babel/helper-module-transforms/-/helper-module-transforms-7.22.9.tgz", - "integrity": "sha512-t+WA2Xn5K+rTeGtC8jCsdAH52bjggG5TKRuRrAGNM/mjIbO4GxvlLMFOEz9wXY5I2XQ60PMFsAG2WIcG82dQMQ==", + "version": "7.25.2", + "resolved": "https://registry.npmjs.org/@babel/helper-module-transforms/-/helper-module-transforms-7.25.2.tgz", + "integrity": "sha512-BjyRAbix6j/wv83ftcVJmBt72QtHI56C7JXZoG2xATiLpmoC7dpd8WnkikExHDVPpi/3qCmO6WY1EaXOluiecQ==", "dev": true, "requires": { - "@babel/helper-environment-visitor": "^7.22.5", - "@babel/helper-module-imports": "^7.22.5", - "@babel/helper-simple-access": "^7.22.5", - "@babel/helper-split-export-declaration": "^7.22.6", - "@babel/helper-validator-identifier": "^7.22.5" + "@babel/helper-module-imports": "^7.24.7", + "@babel/helper-simple-access": "^7.24.7", + "@babel/helper-validator-identifier": "^7.24.7", + "@babel/traverse": "^7.25.2" } }, "@babel/helper-plugin-utils": { - "version": "7.22.5", - "resolved": "https://registry.npmjs.org/@babel/helper-plugin-utils/-/helper-plugin-utils-7.22.5.tgz", - "integrity": "sha512-uLls06UVKgFG9QD4OeFYLEGteMIAa5kpTPcFL28yuCIIzsf6ZyKZMllKVOCZFhiZ5ptnwX4mtKdWCBE/uT4amg==", + "version": "7.24.8", + "resolved": "https://registry.npmjs.org/@babel/helper-plugin-utils/-/helper-plugin-utils-7.24.8.tgz", + "integrity": "sha512-FFWx5142D8h2Mgr/iPVGH5G7w6jDn4jUSpZTyDnQO0Yn7Ks2Kuz6Pci8H6MPCoUJegd/UZQ3tAvfLCxQSnWWwg==", "dev": true }, "@babel/helper-simple-access": { - "version": "7.22.5", - "resolved": "https://registry.npmjs.org/@babel/helper-simple-access/-/helper-simple-access-7.22.5.tgz", - "integrity": "sha512-n0H99E/K+Bika3++WNL17POvo4rKWZ7lZEp1Q+fStVbUi8nxPQEBOlTmCOxW/0JsS56SKKQ+ojAe2pHKJHN35w==", + "version": "7.24.7", + "resolved": "https://registry.npmjs.org/@babel/helper-simple-access/-/helper-simple-access-7.24.7.tgz", + "integrity": "sha512-zBAIvbCMh5Ts+b86r/CjU+4XGYIs+R1j951gxI3KmmxBMhCg4oQMsv6ZXQ64XOm/cvzfU1FmoCyt6+owc5QMYg==", "dev": true, "requires": { - "@babel/types": "^7.22.5" - } - }, - "@babel/helper-split-export-declaration": { - "version": "7.22.6", - "resolved": "https://registry.npmjs.org/@babel/helper-split-export-declaration/-/helper-split-export-declaration-7.22.6.tgz", - "integrity": "sha512-AsUnxuLhRYsisFiaJwvp1QF+I3KjD5FOxut14q/GzovUe6orHLesW2C7d754kRm53h5gqrz6sFl6sxc4BVtE/g==", - "dev": true, - "requires": { - "@babel/types": "^7.22.5" + "@babel/traverse": "^7.24.7", + "@babel/types": "^7.24.7" } }, "@babel/helper-string-parser": { - "version": "7.22.5", - "resolved": "https://registry.npmjs.org/@babel/helper-string-parser/-/helper-string-parser-7.22.5.tgz", - "integrity": "sha512-mM4COjgZox8U+JcXQwPijIZLElkgEpO5rsERVDJTc2qfCDfERyob6k5WegS14SX18IIjv+XD+GrqNumY5JRCDw==", + "version": "7.24.8", + "resolved": "https://registry.npmjs.org/@babel/helper-string-parser/-/helper-string-parser-7.24.8.tgz", + "integrity": "sha512-pO9KhhRcuUyGnJWwyEgnRJTSIZHiT+vMD0kPeD+so0l7mxkMT19g3pjY9GTnHySck/hDzq+dtW/4VgnMkippsQ==", "dev": true }, "@babel/helper-validator-identifier": { - "version": "7.22.5", - "resolved": "https://registry.npmjs.org/@babel/helper-validator-identifier/-/helper-validator-identifier-7.22.5.tgz", - "integrity": "sha512-aJXu+6lErq8ltp+JhkJUfk1MTGyuA4v7f3pA+BJ5HLfNC6nAQ0Cpi9uOquUj8Hehg0aUiHzWQbOVJGao6ztBAQ==", + "version": "7.24.7", + "resolved": "https://registry.npmjs.org/@babel/helper-validator-identifier/-/helper-validator-identifier-7.24.7.tgz", + "integrity": "sha512-rR+PBcQ1SMQDDyF6X0wxtG8QyLCgUB0eRAGguqRLfkCA87l7yAP7ehq8SNj96OOGTO8OBV70KhuFYcIkHXOg0w==", "dev": true }, "@babel/helper-validator-option": { - "version": "7.22.5", - "resolved": "https://registry.npmjs.org/@babel/helper-validator-option/-/helper-validator-option-7.22.5.tgz", - "integrity": "sha512-R3oB6xlIVKUnxNUxbmgq7pKjxpru24zlimpE8WK47fACIlM0II/Hm1RS8IaOI7NgCr6LNS+jl5l75m20npAziw==", + "version": "7.24.8", + "resolved": "https://registry.npmjs.org/@babel/helper-validator-option/-/helper-validator-option-7.24.8.tgz", + "integrity": "sha512-xb8t9tD1MHLungh/AIoWYN+gVHaB9kwlu8gffXGSt3FFEIT7RjS+xWbc2vUD1UTZdIpKj/ab3rdqJ7ufngyi2Q==", "dev": true }, "@babel/helpers": { - "version": "7.22.6", - "resolved": "https://registry.npmjs.org/@babel/helpers/-/helpers-7.22.6.tgz", - "integrity": "sha512-YjDs6y/fVOYFV8hAf1rxd1QvR9wJe1pDBZ2AREKq/SDayfPzgk0PBnVuTCE5X1acEpMMNOVUqoe+OwiZGJ+OaA==", + "version": "7.25.6", + "resolved": "https://registry.npmjs.org/@babel/helpers/-/helpers-7.25.6.tgz", + "integrity": "sha512-Xg0tn4HcfTijTwfDwYlvVCl43V6h4KyVVX2aEm4qdO/PC6L2YvzLHFdmxhoeSA3eslcE6+ZVXHgWwopXYLNq4Q==", "dev": true, "requires": { - "@babel/template": "^7.22.5", - "@babel/traverse": "^7.22.6", - "@babel/types": "^7.22.5" + "@babel/template": "^7.25.0", + "@babel/types": "^7.25.6" } }, "@babel/highlight": { - "version": "7.22.5", - "resolved": "https://registry.npmjs.org/@babel/highlight/-/highlight-7.22.5.tgz", - "integrity": "sha512-BSKlD1hgnedS5XRnGOljZawtag7H1yPfQp0tdNJCHoH6AZ+Pcm9VvkrK59/Yy593Ypg0zMxH2BxD1VPYUQ7UIw==", + "version": "7.24.7", + "resolved": "https://registry.npmjs.org/@babel/highlight/-/highlight-7.24.7.tgz", + "integrity": "sha512-EStJpq4OuY8xYfhGVXngigBJRWxftKX9ksiGDnmlY3o7B/V7KIAc9X4oiK87uPJSc/vs5L869bem5fhZa8caZw==", "dev": true, "requires": { - "@babel/helper-validator-identifier": "^7.22.5", - "chalk": "^2.0.0", - "js-tokens": "^4.0.0" + "@babel/helper-validator-identifier": "^7.24.7", + "chalk": "^2.4.2", + "js-tokens": "^4.0.0", + "picocolors": "^1.0.0" } }, "@babel/parser": { - "version": "7.22.7", - "resolved": "https://registry.npmjs.org/@babel/parser/-/parser-7.22.7.tgz", - "integrity": "sha512-7NF8pOkHP5o2vpmGgNGcfAeCvOYhGLyA3Z4eBQkT1RJlWu47n63bCs93QfJ2hIAFCil7L5P2IWhs1oToVgrL0Q==", - "dev": true + "version": "7.25.6", + "resolved": "https://registry.npmjs.org/@babel/parser/-/parser-7.25.6.tgz", + "integrity": "sha512-trGdfBdbD0l1ZPmcJ83eNxB9rbEax4ALFTF7fN386TMYbeCQbyme5cOEXQhbGXKebwGaB/J52w1mrklMcbgy6Q==", + "dev": true, + "requires": { + "@babel/types": "^7.25.6" + } }, "@babel/runtime": { - "version": "7.23.6", - "resolved": "https://registry.npmjs.org/@babel/runtime/-/runtime-7.23.6.tgz", - "integrity": "sha512-zHd0eUrf5GZoOWVCXp6koAKQTfZV07eit6bGPmJgnZdnSAvvZee6zniW2XMF7Cmc4ISOOnPy3QaSiIJGJkVEDQ==", + "version": "7.25.6", + "resolved": "https://registry.npmjs.org/@babel/runtime/-/runtime-7.25.6.tgz", + "integrity": "sha512-VBj9MYyDb9tuLq7yzqjgzt6Q+IBQLrGZfdjOekyEirZPHxXWoTSGUTMrpsfi58Up73d13NfYLv8HT9vmznjzhQ==", "requires": { "regenerator-runtime": "^0.14.0" } }, "@babel/template": { - "version": "7.22.5", - "resolved": "https://registry.npmjs.org/@babel/template/-/template-7.22.5.tgz", - "integrity": "sha512-X7yV7eiwAxdj9k94NEylvbVHLiVG1nvzCV2EAowhxLTwODV1jl9UzZ48leOC0sH7OnuHrIkllaBgneUykIcZaw==", + "version": "7.25.0", + "resolved": "https://registry.npmjs.org/@babel/template/-/template-7.25.0.tgz", + "integrity": "sha512-aOOgh1/5XzKvg1jvVz7AVrx2piJ2XBi227DHmbY6y+bM9H2FlN+IfecYu4Xl0cNiiVejlsCri89LUsbj8vJD9Q==", "dev": true, "requires": { - "@babel/code-frame": "^7.22.5", - "@babel/parser": "^7.22.5", - "@babel/types": "^7.22.5" + "@babel/code-frame": "^7.24.7", + "@babel/parser": "^7.25.0", + "@babel/types": "^7.25.0" } }, "@babel/traverse": { - "version": "7.23.2", - "resolved": "https://registry.npmjs.org/@babel/traverse/-/traverse-7.23.2.tgz", - "integrity": "sha512-azpe59SQ48qG6nu2CzcMLbxUudtN+dOM9kDbUqGq3HXUJRlo7i8fvPoxQUzYgLZ4cMVmuZgm8vvBpNeRhd6XSw==", - "dev": true, - "requires": { - "@babel/code-frame": "^7.22.13", - "@babel/generator": "^7.23.0", - "@babel/helper-environment-visitor": "^7.22.20", - "@babel/helper-function-name": "^7.23.0", - "@babel/helper-hoist-variables": "^7.22.5", - "@babel/helper-split-export-declaration": "^7.22.6", - "@babel/parser": "^7.23.0", - "@babel/types": "^7.23.0", - "debug": "^4.1.0", + "version": "7.25.6", + "resolved": "https://registry.npmjs.org/@babel/traverse/-/traverse-7.25.6.tgz", + "integrity": "sha512-9Vrcx5ZW6UwK5tvqsj0nGpp/XzqthkT0dqIc9g1AdtygFToNtTF67XzYS//dm+SAK9cp3B9R4ZO/46p63SCjlQ==", + "dev": true, + "requires": { + "@babel/code-frame": "^7.24.7", + "@babel/generator": "^7.25.6", + "@babel/parser": "^7.25.6", + "@babel/template": "^7.25.0", + "@babel/types": "^7.25.6", + "debug": "^4.3.1", "globals": "^11.1.0" - }, - "dependencies": { - "@babel/code-frame": { - "version": "7.22.13", - "resolved": "https://registry.npmjs.org/@babel/code-frame/-/code-frame-7.22.13.tgz", - "integrity": "sha512-XktuhWlJ5g+3TJXc5upd9Ks1HutSArik6jf2eAjYFyIOf4ej3RN+184cZbzDvbPnuTJIUhPKKJE3cIsYTiAT3w==", - "dev": true, - "requires": { - "@babel/highlight": "^7.22.13", - "chalk": "^2.4.2" - } - }, - "@babel/generator": { - "version": "7.23.0", - "resolved": "https://registry.npmjs.org/@babel/generator/-/generator-7.23.0.tgz", - "integrity": "sha512-lN85QRR+5IbYrMWM6Y4pE/noaQtg4pNiqeNGX60eqOfo6gtEj6uw/JagelB8vVztSd7R6M5n1+PQkDbHbBRU4g==", - "dev": true, - "requires": { - "@babel/types": "^7.23.0", - "@jridgewell/gen-mapping": "^0.3.2", - "@jridgewell/trace-mapping": "^0.3.17", - "jsesc": "^2.5.1" - } - }, - "@babel/helper-environment-visitor": { - "version": "7.22.20", - "resolved": "https://registry.npmjs.org/@babel/helper-environment-visitor/-/helper-environment-visitor-7.22.20.tgz", - "integrity": "sha512-zfedSIzFhat/gFhWfHtgWvlec0nqB9YEIVrpuwjruLlXfUSnA8cJB0miHKwqDnQ7d32aKo2xt88/xZptwxbfhA==", - "dev": true - }, - "@babel/helper-function-name": { - "version": "7.23.0", - "resolved": "https://registry.npmjs.org/@babel/helper-function-name/-/helper-function-name-7.23.0.tgz", - "integrity": "sha512-OErEqsrxjZTJciZ4Oo+eoZqeW9UIiOcuYKRJA4ZAgV9myA+pOXhhmpfNCKjEH/auVfEYVFJ6y1Tc4r0eIApqiw==", - "dev": true, - "requires": { - "@babel/template": "^7.22.15", - "@babel/types": "^7.23.0" - } - }, - "@babel/helper-validator-identifier": { - "version": "7.22.20", - "resolved": "https://registry.npmjs.org/@babel/helper-validator-identifier/-/helper-validator-identifier-7.22.20.tgz", - "integrity": "sha512-Y4OZ+ytlatR8AI+8KZfKuL5urKp7qey08ha31L8b3BwewJAoJamTzyvxPR/5D+KkdJCGPq/+8TukHBlY10FX9A==", - "dev": true - }, - "@babel/highlight": { - "version": "7.22.20", - "resolved": "https://registry.npmjs.org/@babel/highlight/-/highlight-7.22.20.tgz", - "integrity": "sha512-dkdMCN3py0+ksCgYmGG8jKeGA/8Tk+gJwSYYlFGxG5lmhfKNoAy004YpLxpS1W2J8m/EK2Ew+yOs9pVRwO89mg==", - "dev": true, - "requires": { - "@babel/helper-validator-identifier": "^7.22.20", - "chalk": "^2.4.2", - "js-tokens": "^4.0.0" - } - }, - "@babel/parser": { - "version": "7.23.0", - "resolved": "https://registry.npmjs.org/@babel/parser/-/parser-7.23.0.tgz", - "integrity": "sha512-vvPKKdMemU85V9WE/l5wZEmImpCtLqbnTvqDS2U1fJ96KrxoW7KrXhNsNCblQlg8Ck4b85yxdTyelsMUgFUXiw==", - "dev": true - }, - "@babel/template": { - "version": "7.22.15", - "resolved": "https://registry.npmjs.org/@babel/template/-/template-7.22.15.tgz", - "integrity": "sha512-QPErUVm4uyJa60rkI73qneDacvdvzxshT3kksGqlGWYdOTIUOwJ7RDUL8sGqslY1uXWSL6xMFKEXDS3ox2uF0w==", - "dev": true, - "requires": { - "@babel/code-frame": "^7.22.13", - "@babel/parser": "^7.22.15", - "@babel/types": "^7.22.15" - } - }, - "@babel/types": { - "version": "7.23.0", - "resolved": "https://registry.npmjs.org/@babel/types/-/types-7.23.0.tgz", - "integrity": "sha512-0oIyUfKoI3mSqMvsxBdclDwxXKXAUA8v/apZbc+iSyARYou1o8ZGDxbUYyLFoW2arqS2jDGqJuZvv1d/io1axg==", - "dev": true, - "requires": { - "@babel/helper-string-parser": "^7.22.5", - "@babel/helper-validator-identifier": "^7.22.20", - "to-fast-properties": "^2.0.0" - } - } } }, "@babel/types": { - "version": "7.22.5", - "resolved": "https://registry.npmjs.org/@babel/types/-/types-7.22.5.tgz", - "integrity": "sha512-zo3MIHGOkPOfoRXitsgHLjEXmlDaD/5KU1Uzuc9GNiZPhSqVxVRtxuPaSBZDsYZ9qV88AjtMtWW7ww98loJ9KA==", + "version": "7.25.6", + "resolved": "https://registry.npmjs.org/@babel/types/-/types-7.25.6.tgz", + "integrity": "sha512-/l42B1qxpG6RdfYf343Uw1vmDjeNhneUXtzhojE7pDgfpEypmRhI6j1kr17XCVv4Cgl9HdAiQY2x0GwKm7rWCw==", "dev": true, "requires": { - "@babel/helper-string-parser": "^7.22.5", - "@babel/helper-validator-identifier": "^7.22.5", + "@babel/helper-string-parser": "^7.24.8", + "@babel/helper-validator-identifier": "^7.24.7", "to-fast-properties": "^2.0.0" } }, @@ -435,50 +328,42 @@ "dev": true }, "@jridgewell/gen-mapping": { - "version": "0.3.3", - "resolved": "https://registry.npmjs.org/@jridgewell/gen-mapping/-/gen-mapping-0.3.3.tgz", - "integrity": "sha512-HLhSWOLRi875zjjMG/r+Nv0oCW8umGb0BgEhyX3dDX3egwZtB8PqLnjz3yedt8R5StBrzcg4aBpnh8UA9D1BoQ==", + "version": "0.3.5", + "resolved": "https://registry.npmjs.org/@jridgewell/gen-mapping/-/gen-mapping-0.3.5.tgz", + "integrity": "sha512-IzL8ZoEDIBRWEzlCcRhOaCupYyN5gdIK+Q6fbFdPDg6HqX6jpkItn7DFIpW9LQzXG6Df9sA7+OKnq0qlz/GaQg==", "dev": true, "requires": { - "@jridgewell/set-array": "^1.0.1", + "@jridgewell/set-array": "^1.2.1", "@jridgewell/sourcemap-codec": "^1.4.10", - "@jridgewell/trace-mapping": "^0.3.9" + "@jridgewell/trace-mapping": "^0.3.24" } }, "@jridgewell/resolve-uri": { - "version": "3.1.0", - "resolved": "https://registry.npmjs.org/@jridgewell/resolve-uri/-/resolve-uri-3.1.0.tgz", - "integrity": "sha512-F2msla3tad+Mfht5cJq7LSXcdudKTWCVYUgw6pLFOOHSTtZlj6SWNYAp+AhuqLmWdBO2X5hPrLcu8cVP8fy28w==", + "version": "3.1.2", + "resolved": "https://registry.npmjs.org/@jridgewell/resolve-uri/-/resolve-uri-3.1.2.tgz", + "integrity": "sha512-bRISgCIjP20/tbWSPWMEi54QVPRZExkuD9lJL+UIxUKtwVJA8wW1Trb1jMs1RFXo1CBTNZ/5hpC9QvmKWdopKw==", "dev": true }, "@jridgewell/set-array": { - "version": "1.1.2", - "resolved": "https://registry.npmjs.org/@jridgewell/set-array/-/set-array-1.1.2.tgz", - "integrity": "sha512-xnkseuNADM0gt2bs+BvhO0p78Mk762YnZdsuzFV018NoG1Sj1SCQvpSqa7XUaTam5vAGasABV9qXASMKnFMwMw==", + "version": "1.2.1", + "resolved": "https://registry.npmjs.org/@jridgewell/set-array/-/set-array-1.2.1.tgz", + "integrity": "sha512-R8gLRTZeyp03ymzP/6Lil/28tGeGEzhx1q2k703KGWRAI1VdvPIXdG70VJc2pAMw3NA6JKL5hhFu1sJX0Mnn/A==", "dev": true }, "@jridgewell/sourcemap-codec": { - "version": "1.4.15", - "resolved": "https://registry.npmjs.org/@jridgewell/sourcemap-codec/-/sourcemap-codec-1.4.15.tgz", - "integrity": "sha512-eF2rxCRulEKXHTRiDrDy6erMYWqNw4LPdQ8UQA4huuxaQsVeRPFl2oM8oDGxMFhJUWZf9McpLtJasDDZb/Bpeg==", + "version": "1.5.0", + "resolved": "https://registry.npmjs.org/@jridgewell/sourcemap-codec/-/sourcemap-codec-1.5.0.tgz", + "integrity": "sha512-gv3ZRaISU3fjPAgNsriBRqGWQL6quFx04YMPW/zD8XMLsU32mhCCbfbO6KZFLjvYpCZ8zyDEgqsgf+PwPaM7GQ==", "dev": true }, "@jridgewell/trace-mapping": { - "version": "0.3.18", - "resolved": "https://registry.npmjs.org/@jridgewell/trace-mapping/-/trace-mapping-0.3.18.tgz", - "integrity": "sha512-w+niJYzMHdd7USdiH2U6869nqhD2nbfZXND5Yp93qIbEmnDNk7PD48o+YchRVpzMU7M6jVCbenTR7PA1FLQ9pA==", + "version": "0.3.25", + "resolved": "https://registry.npmjs.org/@jridgewell/trace-mapping/-/trace-mapping-0.3.25.tgz", + "integrity": "sha512-vNk6aEwybGtawWmy/PzwnGDOjCkLWSD2wqvjGGAgOAwCGWySYXfYoxt00IJkTF+8Lb57DwOb3Aa0o9CApepiYQ==", "dev": true, "requires": { - "@jridgewell/resolve-uri": "3.1.0", - "@jridgewell/sourcemap-codec": "1.4.14" - }, - "dependencies": { - "@jridgewell/sourcemap-codec": { - "version": "1.4.14", - "resolved": "https://registry.npmjs.org/@jridgewell/sourcemap-codec/-/sourcemap-codec-1.4.14.tgz", - "integrity": "sha512-XPSJHWmi394fuUuzDnGz1wiKqWfo1yXecHQMRf2l6hztTO+nPru658AyDngaBe7isIxEkRsPR3FZh+s7iVa4Uw==", - "dev": true - } + "@jridgewell/resolve-uri": "^3.1.0", + "@jridgewell/sourcemap-codec": "^1.4.14" } }, "@nodelib/fs.scandir": { @@ -605,16 +490,19 @@ "dev": true }, "@types/node": { - "version": "20.4.5", - "resolved": "https://registry.npmjs.org/@types/node/-/node-20.4.5.tgz", - "integrity": "sha512-rt40Nk13II9JwQBdeYqmbn2Q6IVTA5uPhvSO+JVqdXw/6/4glI6oR9ezty/A9Hg5u7JH4OmYmuQ+XvjKm0Datg==", + "version": "22.5.1", + "resolved": "https://registry.npmjs.org/@types/node/-/node-22.5.1.tgz", + "integrity": "sha512-KkHsxej0j9IW1KKOOAA/XBA0z08UFSrRQHErzEfA3Vgq57eXIMYboIlHJuYIfd+lwCQjtKqUu3UnmKbtUc9yRw==", "dev": true, - "optional": true + "optional": true, + "requires": { + "undici-types": "~6.19.2" + } }, "@types/yauzl": { - "version": "2.10.0", - "resolved": "https://registry.npmjs.org/@types/yauzl/-/yauzl-2.10.0.tgz", - "integrity": "sha512-Cn6WYCm0tXv8p6k+A8PvbDG763EDpBoTzHdA+Q/MF6H3sapGjCm9NzoaJncJS9tUKSuCoDs9XHxYYsQDgxR6kw==", + "version": "2.10.3", + "resolved": "https://registry.npmjs.org/@types/yauzl/-/yauzl-2.10.3.tgz", + "integrity": "sha512-oJoftv0LSuaDZE3Le4DbKX+KS9G36NzOeSap90UIK0yMA/NhKJhqlSGtNDORNRaIbQfzjXDrQa0ytJ6mNRGz/Q==", "dev": true, "optional": true, "requires": { @@ -845,21 +733,6 @@ "@istanbuljs/schema": "^0.1.2", "istanbul-lib-instrument": "^5.0.4", "test-exclude": "^6.0.0" - }, - "dependencies": { - "istanbul-lib-instrument": { - "version": "5.2.1", - "resolved": "https://registry.npmjs.org/istanbul-lib-instrument/-/istanbul-lib-instrument-5.2.1.tgz", - "integrity": "sha512-pzqtp31nLv/XFOzXGuvhCb8qhjmTVo5vjVk19XE4CRlSWz0KoeJ3bw9XsA7nOp9YBf4qHjwBxkDzKcME/J29Yg==", - "dev": true, - "requires": { - "@babel/core": "^7.12.3", - "@babel/parser": "^7.14.7", - "@istanbuljs/schema": "^0.1.2", - "istanbul-lib-coverage": "^3.2.0", - "semver": "^6.3.0" - } - } } }, "balanced-match": { @@ -903,15 +776,15 @@ } }, "browserslist": { - "version": "4.21.10", - "resolved": "https://registry.npmjs.org/browserslist/-/browserslist-4.21.10.tgz", - "integrity": "sha512-bipEBdZfVH5/pwrvqc+Ub0kUPVfGUhlKxbvfD+z1BDnPEO/X98ruXGA1WP5ASpAFKan7Qr6j736IacbZQuAlKQ==", + "version": "4.23.3", + "resolved": "https://registry.npmjs.org/browserslist/-/browserslist-4.23.3.tgz", + "integrity": "sha512-btwCFJVjI4YWDNfau8RhZ+B1Q/VLoUITrm3RlP6y1tYGWIOa+InuYiRGXUBXo8nA1qKmHMyLB/iVQg5TT4eFoA==", "dev": true, "requires": { - "caniuse-lite": "^1.0.30001517", - "electron-to-chromium": "^1.4.477", - "node-releases": "^2.0.13", - "update-browserslist-db": "^1.0.11" + "caniuse-lite": "^1.0.30001646", + "electron-to-chromium": "^1.5.4", + "node-releases": "^2.0.18", + "update-browserslist-db": "^1.1.0" } }, "buffer": { @@ -1004,15 +877,15 @@ "dev": true }, "caniuse-lite": { - "version": "1.0.30001518", - "resolved": "https://registry.npmjs.org/caniuse-lite/-/caniuse-lite-1.0.30001518.tgz", - "integrity": "sha512-rup09/e3I0BKjncL+FesTayKtPrdwKhUufQFd3riFw1hHg8JmIFoInYfB102cFcY/pPgGmdyl/iy+jgiDi2vdA==", + "version": "1.0.30001653", + "resolved": "https://registry.npmjs.org/caniuse-lite/-/caniuse-lite-1.0.30001653.tgz", + "integrity": "sha512-XGWQVB8wFQ2+9NZwZ10GxTYC5hk0Fa+q8cSkr0tgvMhYhMHP/QC+WTgrePMDBWiWc/pV+1ik82Al20XOK25Gcw==", "dev": true }, "chai": { - "version": "4.3.10", - "resolved": "https://registry.npmjs.org/chai/-/chai-4.3.10.tgz", - "integrity": "sha512-0UXG04VuVbruMUYbJ6JctvH0YnC/4q3/AkT18q4NaITo91CUm0liMS9VqzT9vZhVQ/1eqPanMWjBM+Juhfb/9g==", + "version": "4.5.0", + "resolved": "https://registry.npmjs.org/chai/-/chai-4.5.0.tgz", + "integrity": "sha512-RITGBfijLkBddZvnn8jdqoTypxvqbOLYQkGGxXzeFjVHvudaPw0HNFD9x928/eUwYWd2dPCugVqspGALTZZQKw==", "dev": true, "requires": { "assertion-error": "^1.1.0", @@ -1021,13 +894,13 @@ "get-func-name": "^2.0.2", "loupe": "^2.3.6", "pathval": "^1.1.1", - "type-detect": "^4.0.8" + "type-detect": "^4.1.0" } }, "chai-as-promised": { - "version": "7.1.1", - "resolved": "https://registry.npmjs.org/chai-as-promised/-/chai-as-promised-7.1.1.tgz", - "integrity": "sha512-azL6xMoi+uxu6z4rhWQ1jbdUhOMhis2PvscD/xjLqNMkv3BPPp2JyyuTHOrf9BOosGpNQ11v6BKv/g57RXbiaA==", + "version": "7.1.2", + "resolved": "https://registry.npmjs.org/chai-as-promised/-/chai-as-promised-7.1.2.tgz", + "integrity": "sha512-aBDHZxRzYnUYuIAIPBH2s511DjlKPzXNlXSGFC8CwmroWQLfrW0LtE1nK3MAwwNhJPa9raEjNCmRoFpG0Hurdw==", "dev": true, "requires": { "check-error": "^1.0.2" @@ -1134,9 +1007,9 @@ "integrity": "sha512-nTjqfcBFEipKdXCv4YDQWCfmcLZKm81ldF0pAopTvyrFGVbcR6P/VAAd5G7N+0tTr8QqiU0tFadD6FK4NtJwOA==" }, "convert-source-map": { - "version": "1.9.0", - "resolved": "https://registry.npmjs.org/convert-source-map/-/convert-source-map-1.9.0.tgz", - "integrity": "sha512-ASFBup0Mz1uyiIjANan1jzLQami9z1PoYSZCiiYW2FczPbenXc45FZdBZLzOT+r6+iciuEModtmCti+hjaAk0A==", + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/convert-source-map/-/convert-source-map-2.0.0.tgz", + "integrity": "sha512-Kvp459HrV2FEJ1CAsi1Ku+MY3kasH19TFykTz2xWmMeq6bk2NU3XXvfJ+Q61m0xktWwt+1HSYf3JZsTms3aRJg==", "dev": true }, "cookie-signature": { @@ -1235,9 +1108,9 @@ "dev": true }, "deep-eql": { - "version": "4.1.3", - "resolved": "https://registry.npmjs.org/deep-eql/-/deep-eql-4.1.3.tgz", - "integrity": "sha512-WaEtAOpRA1MQ0eohqZjpGD8zdI0Ovsm8mmFhaDN8dvDZzyoUMcYDnf5Y6iu7HTXxf8JDS23qWa4a+hKCDyOPzw==", + "version": "4.1.4", + "resolved": "https://registry.npmjs.org/deep-eql/-/deep-eql-4.1.4.tgz", + "integrity": "sha512-SUwdGfqdKOwxCPeVYjwSyRpJ7Z+fhpwIAtmCUdZIWZ/YP5R9WAsyuSgpLVDi9bjWoN2LXHNss/dk3urXtdQxGg==", "dev": true, "requires": { "type-detect": "^4.0.0" @@ -1305,9 +1178,9 @@ "integrity": "sha512-WMwm9LhRUo+WUaRN+vRuETqG89IgZphVSNkdFgeb6sS/E4OrDIN7t48CAewSHXc6C8lefD8KKfr5vY61brQlow==" }, "electron-to-chromium": { - "version": "1.4.479", - "resolved": "https://registry.npmjs.org/electron-to-chromium/-/electron-to-chromium-1.4.479.tgz", - "integrity": "sha512-ABv1nHMIR8I5n3O3Een0gr6i0mfM+YcTZqjHy3pAYaOjgFG+BMquuKrSyfYf5CbEkLr9uM05RA3pOk4udNB/aQ==", + "version": "1.5.13", + "resolved": "https://registry.npmjs.org/electron-to-chromium/-/electron-to-chromium-1.5.13.tgz", + "integrity": "sha512-lbBcvtIJ4J6sS4tb5TLp1b4LyfCdMkwStzXPyAgVgTRAsep4bvrAGaBOP7ZJtQMNJpSQ9SqG4brWOroNaQtm7Q==", "dev": true }, "emoji-regex": { @@ -1429,9 +1302,9 @@ "dev": true }, "escalade": { - "version": "3.1.1", - "resolved": "https://registry.npmjs.org/escalade/-/escalade-3.1.1.tgz", - "integrity": "sha512-k0er2gUkLf8O0zKJiAhmkTnJlTvINGv7ygDNPbeIsX/TJjGJZHuh9B2UxbsaEkmlEo9MfhrSzmhIlhRlI2GXnw==", + "version": "3.1.2", + "resolved": "https://registry.npmjs.org/escalade/-/escalade-3.1.2.tgz", + "integrity": "sha512-ErCHMCae19vR8vQGe50xIsVomy19rg6gFu3+r3jkEO46suLMWBksvVyoGgQV+jOfl84ZSOSlmv6Gxa89PmTGmA==", "dev": true }, "escape-html": { @@ -2361,6 +2234,20 @@ "get-intrinsic": "^1.1.1" } }, + "glob": { + "version": "7.2.3", + "resolved": "https://registry.npmjs.org/glob/-/glob-7.2.3.tgz", + "integrity": "sha512-nFR0zLpU2YCaRxwoCJvL6UvCH2JFyFVIvwTLsIf21AuHlMskA1hhTdk+LlYJtOlYt9v6dvszD2BGRqBL+iQK9Q==", + "dev": true, + "requires": { + "fs.realpath": "^1.0.0", + "inflight": "^1.0.4", + "inherits": "2", + "minimatch": "^3.1.1", + "once": "^1.3.0", + "path-is-absolute": "^1.0.0" + } + }, "glob-parent": { "version": "6.0.2", "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-6.0.2.tgz", @@ -2788,9 +2675,9 @@ "dev": true }, "istanbul-lib-coverage": { - "version": "3.2.0", - "resolved": "https://registry.npmjs.org/istanbul-lib-coverage/-/istanbul-lib-coverage-3.2.0.tgz", - "integrity": "sha512-eOeJ5BHCmHYvQK7xt9GkdHuzuCGS1Y6g9Gvnx3Ym33fz/HpLRYxiS0wHNr+m/MBC8B647Xt608vCDEvhl9c6Mw==", + "version": "3.2.2", + "resolved": "https://registry.npmjs.org/istanbul-lib-coverage/-/istanbul-lib-coverage-3.2.2.tgz", + "integrity": "sha512-O8dpsF+r0WV/8MNRKfnmrtCWhuKjxrq2w+jpzBL5UZKTi2LeVWnWOmWRxFlesJONmc+wLAGvKQZEOanko0LFTg==", "dev": true }, "istanbul-lib-hook": { @@ -2803,14 +2690,15 @@ } }, "istanbul-lib-instrument": { - "version": "4.0.3", - "resolved": "https://registry.npmjs.org/istanbul-lib-instrument/-/istanbul-lib-instrument-4.0.3.tgz", - "integrity": "sha512-BXgQl9kf4WTCPCCpmFGoJkz/+uhvm7h7PFKUYxh7qarQd3ER33vHG//qaE8eN25l07YqZPpHXU9I09l/RD5aGQ==", + "version": "5.2.1", + "resolved": "https://registry.npmjs.org/istanbul-lib-instrument/-/istanbul-lib-instrument-5.2.1.tgz", + "integrity": "sha512-pzqtp31nLv/XFOzXGuvhCb8qhjmTVo5vjVk19XE4CRlSWz0KoeJ3bw9XsA7nOp9YBf4qHjwBxkDzKcME/J29Yg==", "dev": true, "requires": { - "@babel/core": "^7.7.5", + "@babel/core": "^7.12.3", + "@babel/parser": "^7.14.7", "@istanbuljs/schema": "^0.1.2", - "istanbul-lib-coverage": "^3.0.0", + "istanbul-lib-coverage": "^3.2.0", "semver": "^6.3.0" } }, @@ -2826,6 +2714,14 @@ "p-map": "^3.0.0", "rimraf": "^3.0.0", "uuid": "^8.3.2" + }, + "dependencies": { + "uuid": { + "version": "8.3.2", + "resolved": "https://registry.npmjs.org/uuid/-/uuid-8.3.2.tgz", + "integrity": "sha512-+NYs2QeMWy+GWFOEm9xnn6HCDp0l7QBD7ml8zLUmJ+93Q5NF0NocErnwkTkXVFNiX3/fpC6afS8Dhb/gz7R7eg==", + "dev": true + } } }, "istanbul-lib-report": { @@ -2845,15 +2741,6 @@ "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==", "dev": true }, - "lru-cache": { - "version": "6.0.0", - "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-6.0.0.tgz", - "integrity": "sha512-Jo6dJ04CmSjuznwJSS3pUeWmd/H0ffTlkXXgwZi+eq1UCmqQwCh+eLsYOYCwY991i2Fah4h1BEMCx4qThGbsiA==", - "dev": true, - "requires": { - "yallist": "^4.0.0" - } - }, "make-dir": { "version": "4.0.0", "resolved": "https://registry.npmjs.org/make-dir/-/make-dir-4.0.0.tgz", @@ -2864,13 +2751,10 @@ } }, "semver": { - "version": "7.5.4", - "resolved": "https://registry.npmjs.org/semver/-/semver-7.5.4.tgz", - "integrity": "sha512-1bCSESV6Pv+i21Hvpxp3Dx+pSD8lIPt8uVjRrxAUt/nbswYc+tK6Y2btiULjd4+fnq15PX+nqQDC7Oft7WkwcA==", - "dev": true, - "requires": { - "lru-cache": "^6.0.0" - } + "version": "7.6.3", + "resolved": "https://registry.npmjs.org/semver/-/semver-7.6.3.tgz", + "integrity": "sha512-oVekP1cKtI+CTDvHWYFUcMtsK/00wmAEfyqKfNdARm8u1wNVhSgaX7A8d4UuIlUI5e84iEwOhs7ZPYRmzU9U6A==", + "dev": true }, "supports-color": { "version": "7.2.0", @@ -2880,12 +2764,6 @@ "requires": { "has-flag": "^4.0.0" } - }, - "yallist": { - "version": "4.0.0", - "resolved": "https://registry.npmjs.org/yallist/-/yallist-4.0.0.tgz", - "integrity": "sha512-3wdGidZyq5PB084XLES5TpOSRA3wjXAlIWMhum2kRcv/41Sn2emQ0dycQW4uZXLejwKvg6EsvbdlVL+FYEct7A==", - "dev": true } } }, @@ -2901,9 +2779,9 @@ } }, "istanbul-reports": { - "version": "3.1.6", - "resolved": "https://registry.npmjs.org/istanbul-reports/-/istanbul-reports-3.1.6.tgz", - "integrity": "sha512-TLgnMkKg3iTDsQ9PbPTdpfAK2DzjF9mqUG7RMgcQl8oFjad8ob4laGxv5XV5U9MAfx8D6tSJiUyuAwzLicaxlg==", + "version": "3.1.7", + "resolved": "https://registry.npmjs.org/istanbul-reports/-/istanbul-reports-3.1.7.tgz", + "integrity": "sha512-BewmUXImeuRk2YY0PVbxgKAysvhRPUQE0h5QRM++nVWyubKGV0l8qQ5op8+B2DOmwSe63Jivj0BjkPQVf8fP5g==", "dev": true, "requires": { "html-escaper": "^2.0.0", @@ -3130,81 +3008,99 @@ "integrity": "sha512-cCi6g3/Zr1iqQi6ySbseM1Xvooa98N0w31jzUYrXPX2xqObmFGHJ0tQ5u74H3mVh7wLouTseZyYIq39g8cNp1w==" }, "meteor-node-stubs": { - "version": "1.2.7", - "resolved": "https://registry.npmjs.org/meteor-node-stubs/-/meteor-node-stubs-1.2.7.tgz", - "integrity": "sha512-20bAFUhEIOD/Cos2nmvhqf2NOKpTf63WVQ+nwuaX2OFj31sU6GL4KkNylkWum8McwsH0LsMr/F+UHhduTX7KRg==", + "version": "1.2.9", + "resolved": "https://registry.npmjs.org/meteor-node-stubs/-/meteor-node-stubs-1.2.9.tgz", + "integrity": "sha512-EKRezc1/PblYtYiK4BOT3h5geWDo9AFBBSYNamPNh8AC5msUbVCcg8kekzAa7r7JPzBX8nZWaXEQVar4t8q/Hg==", "requires": { - "assert": "^2.0.0", + "@meteorjs/crypto-browserify": "^3.12.1", + "assert": "^2.1.0", "browserify-zlib": "^0.2.0", "buffer": "^5.7.1", "console-browserify": "^1.2.0", "constants-browserify": "^1.0.0", - "crypto-browserify": "^3.12.0", - "domain-browser": "^4.22.0", + "domain-browser": "^4.23.0", "elliptic": "^6.5.4", "events": "^3.3.0", "https-browserify": "^1.0.0", "os-browserify": "^0.3.0", - "path-browserify": "^1.0.0", + "path-browserify": "^1.0.1", "process": "^0.11.10", "punycode": "^1.4.1", "querystring-es3": "^0.2.1", - "readable-stream": "^3.6.0", + "readable-stream": "^3.6.2", "stream-browserify": "^3.0.0", "stream-http": "^3.2.0", "string_decoder": "^1.3.0", "timers-browserify": "^2.0.12", "tty-browserify": "0.0.1", - "url": "^0.11.0", - "util": "^0.12.4", + "url": "^0.11.3", + "util": "^0.12.5", "vm-browserify": "^1.1.2" }, "dependencies": { + "@meteorjs/crypto-browserify": { + "version": "3.12.1", + "requires": { + "browserify-cipher": "^1.0.1", + "browserify-sign": "^4.2.3", + "create-ecdh": "^4.0.4", + "create-hash": "^1.2.0", + "create-hmac": "^1.1.7", + "diffie-hellman": "^5.0.3", + "hash-base": "~3.0.4", + "inherits": "^2.0.4", + "pbkdf2": "^3.1.2", + "public-encrypt": "^4.0.3", + "randombytes": "^2.1.0", + "randomfill": "^1.0.4" + }, + "dependencies": { + "hash-base": { + "version": "3.0.4", + "requires": { + "inherits": "^2.0.1", + "safe-buffer": "^5.0.1" + } + } + } + }, "asn1.js": { - "version": "5.4.1", - "bundled": true, + "version": "4.10.1", "requires": { "bn.js": "^4.0.0", "inherits": "^2.0.1", - "minimalistic-assert": "^1.0.0", - "safer-buffer": "^2.1.0" + "minimalistic-assert": "^1.0.0" }, "dependencies": { "bn.js": { - "version": "4.12.0", - "bundled": true + "version": "4.12.0" } } }, "assert": { - "version": "2.0.0", - "bundled": true, + "version": "2.1.0", "requires": { - "es6-object-assign": "^1.1.0", - "is-nan": "^1.2.1", - "object-is": "^1.0.1", - "util": "^0.12.0" + "call-bind": "^1.0.2", + "is-nan": "^1.3.2", + "object-is": "^1.1.5", + "object.assign": "^4.1.4", + "util": "^0.12.5" } }, "available-typed-arrays": { - "version": "1.0.4", - "bundled": true + "version": "1.0.5" }, "base64-js": { - "version": "1.5.1", - "bundled": true + "version": "1.5.1" }, "bn.js": { - "version": "5.2.0", - "bundled": true + "version": "5.2.0" }, "brorand": { - "version": "1.1.0", - "bundled": true + "version": "1.1.0" }, "browserify-aes": { "version": "1.2.0", - "bundled": true, "requires": { "buffer-xor": "^1.0.3", "cipher-base": "^1.0.0", @@ -3216,7 +3112,6 @@ }, "browserify-cipher": { "version": "1.0.1", - "bundled": true, "requires": { "browserify-aes": "^1.0.4", "browserify-des": "^1.0.0", @@ -3225,7 +3120,6 @@ }, "browserify-des": { "version": "1.0.2", - "bundled": true, "requires": { "cipher-base": "^1.0.1", "des.js": "^1.0.0", @@ -3235,91 +3129,123 @@ }, "browserify-rsa": { "version": "4.1.0", - "bundled": true, "requires": { "bn.js": "^5.0.0", "randombytes": "^2.0.1" } }, "browserify-sign": { - "version": "4.2.1", - "bundled": true, + "version": "4.2.3", "requires": { - "bn.js": "^5.1.1", - "browserify-rsa": "^4.0.1", + "bn.js": "^5.2.1", + "browserify-rsa": "^4.1.0", "create-hash": "^1.2.0", "create-hmac": "^1.1.7", - "elliptic": "^6.5.3", + "elliptic": "^6.5.5", + "hash-base": "~3.0", "inherits": "^2.0.4", - "parse-asn1": "^5.1.5", - "readable-stream": "^3.6.0", - "safe-buffer": "^5.2.0" + "parse-asn1": "^5.1.7", + "readable-stream": "^2.3.8", + "safe-buffer": "^5.2.1" + }, + "dependencies": { + "bn.js": { + "version": "5.2.1" + }, + "hash-base": { + "version": "3.0.4", + "requires": { + "inherits": "^2.0.1", + "safe-buffer": "^5.0.1" + } + }, + "readable-stream": { + "version": "2.3.8", + "requires": { + "core-util-is": "~1.0.0", + "inherits": "~2.0.3", + "isarray": "~1.0.0", + "process-nextick-args": "~2.0.0", + "safe-buffer": "~5.1.1", + "string_decoder": "~1.1.1", + "util-deprecate": "~1.0.1" + }, + "dependencies": { + "safe-buffer": { + "version": "5.1.2" + } + } + }, + "string_decoder": { + "version": "1.1.1", + "requires": { + "safe-buffer": "~5.1.0" + }, + "dependencies": { + "safe-buffer": { + "version": "5.1.2" + } + } + } } }, "browserify-zlib": { "version": "0.2.0", - "bundled": true, "requires": { "pako": "~1.0.5" } }, "buffer": { "version": "5.7.1", - "bundled": true, "requires": { "base64-js": "^1.3.1", "ieee754": "^1.1.13" } }, "buffer-xor": { - "version": "1.0.3", - "bundled": true + "version": "1.0.3" }, "builtin-status-codes": { - "version": "3.0.0", - "bundled": true + "version": "3.0.0" }, "call-bind": { - "version": "1.0.2", - "bundled": true, + "version": "1.0.5", "requires": { - "function-bind": "^1.1.1", - "get-intrinsic": "^1.0.2" + "function-bind": "^1.1.2", + "get-intrinsic": "^1.2.1", + "set-function-length": "^1.1.1" } }, "cipher-base": { "version": "1.0.4", - "bundled": true, "requires": { "inherits": "^2.0.1", "safe-buffer": "^5.0.1" } }, "console-browserify": { - "version": "1.2.0", - "bundled": true + "version": "1.2.0" }, "constants-browserify": { - "version": "1.0.0", - "bundled": true + "version": "1.0.0" + }, + "core-util-is": { + "version": "1.0.3" }, "create-ecdh": { "version": "4.0.4", - "bundled": true, "requires": { "bn.js": "^4.1.0", "elliptic": "^6.5.3" }, "dependencies": { "bn.js": { - "version": "4.12.0", - "bundled": true + "version": "4.12.0" } } }, "create-hash": { "version": "1.2.0", - "bundled": true, "requires": { "cipher-base": "^1.0.1", "inherits": "^2.0.1", @@ -3330,7 +3256,6 @@ }, "create-hmac": { "version": "1.1.7", - "bundled": true, "requires": { "cipher-base": "^1.0.3", "create-hash": "^1.1.0", @@ -3340,33 +3265,24 @@ "sha.js": "^2.4.8" } }, - "crypto-browserify": { - "version": "3.12.0", - "bundled": true, + "define-data-property": { + "version": "1.1.1", "requires": { - "browserify-cipher": "^1.0.0", - "browserify-sign": "^4.0.0", - "create-ecdh": "^4.0.0", - "create-hash": "^1.1.0", - "create-hmac": "^1.1.0", - "diffie-hellman": "^5.0.0", - "inherits": "^2.0.1", - "pbkdf2": "^3.0.3", - "public-encrypt": "^4.0.0", - "randombytes": "^2.0.0", - "randomfill": "^1.0.3" + "get-intrinsic": "^1.2.1", + "gopd": "^1.0.1", + "has-property-descriptors": "^1.0.0" } }, "define-properties": { - "version": "1.1.3", - "bundled": true, + "version": "1.2.1", "requires": { - "object-keys": "^1.0.12" + "define-data-property": "^1.0.1", + "has-property-descriptors": "^1.0.0", + "object-keys": "^1.1.1" } }, "des.js": { "version": "1.0.1", - "bundled": true, "requires": { "inherits": "^2.0.1", "minimalistic-assert": "^1.0.0" @@ -3374,7 +3290,6 @@ }, "diffie-hellman": { "version": "5.0.3", - "bundled": true, "requires": { "bn.js": "^4.1.0", "miller-rabin": "^4.0.0", @@ -3382,18 +3297,15 @@ }, "dependencies": { "bn.js": { - "version": "4.12.0", - "bundled": true + "version": "4.12.0" } } }, "domain-browser": { - "version": "4.22.0", - "bundled": true + "version": "4.23.0" }, "elliptic": { - "version": "6.5.4", - "bundled": true, + "version": "6.5.5", "requires": { "bn.js": "^4.11.9", "brorand": "^1.1.0", @@ -3405,93 +3317,64 @@ }, "dependencies": { "bn.js": { - "version": "4.12.0", - "bundled": true + "version": "4.12.0" } } }, - "es-abstract": { - "version": "1.18.3", - "bundled": true, - "requires": { - "call-bind": "^1.0.2", - "es-to-primitive": "^1.2.1", - "function-bind": "^1.1.1", - "get-intrinsic": "^1.1.1", - "has": "^1.0.3", - "has-symbols": "^1.0.2", - "is-callable": "^1.2.3", - "is-negative-zero": "^2.0.1", - "is-regex": "^1.1.3", - "is-string": "^1.0.6", - "object-inspect": "^1.10.3", - "object-keys": "^1.1.1", - "object.assign": "^4.1.2", - "string.prototype.trimend": "^1.0.4", - "string.prototype.trimstart": "^1.0.4", - "unbox-primitive": "^1.0.1" - } - }, - "es-to-primitive": { - "version": "1.2.1", - "bundled": true, - "requires": { - "is-callable": "^1.1.4", - "is-date-object": "^1.0.1", - "is-symbol": "^1.0.2" - } - }, - "es6-object-assign": { - "version": "1.1.0", - "bundled": true - }, "events": { - "version": "3.3.0", - "bundled": true + "version": "3.3.0" }, "evp_bytestokey": { "version": "1.0.3", - "bundled": true, "requires": { "md5.js": "^1.3.4", "safe-buffer": "^5.1.1" } }, - "foreach": { - "version": "2.0.5", - "bundled": true + "for-each": { + "version": "0.3.3", + "requires": { + "is-callable": "^1.1.3" + } }, "function-bind": { - "version": "1.1.1", - "bundled": true + "version": "1.1.2" }, "get-intrinsic": { - "version": "1.1.1", - "bundled": true, + "version": "1.2.2", "requires": { - "function-bind": "^1.1.1", - "has": "^1.0.3", - "has-symbols": "^1.0.1" + "function-bind": "^1.1.2", + "has-proto": "^1.0.1", + "has-symbols": "^1.0.3", + "hasown": "^2.0.0" } }, - "has": { - "version": "1.0.3", - "bundled": true, + "gopd": { + "version": "1.0.1", "requires": { - "function-bind": "^1.1.1" + "get-intrinsic": "^1.1.3" } }, - "has-bigints": { + "has-property-descriptors": { "version": "1.0.1", - "bundled": true + "requires": { + "get-intrinsic": "^1.2.2" + } + }, + "has-proto": { + "version": "1.0.1" }, "has-symbols": { - "version": "1.0.2", - "bundled": true + "version": "1.0.3" + }, + "has-tostringtag": { + "version": "1.0.0", + "requires": { + "has-symbols": "^1.0.2" + } }, "hash-base": { "version": "3.1.0", - "bundled": true, "requires": { "inherits": "^2.0.4", "readable-stream": "^3.6.0", @@ -3500,15 +3383,19 @@ }, "hash.js": { "version": "1.1.7", - "bundled": true, "requires": { "inherits": "^2.0.3", "minimalistic-assert": "^1.0.1" } }, + "hasown": { + "version": "2.0.0", + "requires": { + "function-bind": "^1.1.2" + } + }, "hmac-drbg": { "version": "1.0.1", - "bundled": true, "requires": { "hash.js": "^1.0.3", "minimalistic-assert": "^1.0.0", @@ -3516,96 +3403,48 @@ } }, "https-browserify": { - "version": "1.0.0", - "bundled": true + "version": "1.0.0" }, "ieee754": { - "version": "1.2.1", - "bundled": true + "version": "1.2.1" }, "inherits": { - "version": "2.0.4", - "bundled": true + "version": "2.0.4" }, "is-arguments": { - "version": "1.1.0", - "bundled": true, - "requires": { - "call-bind": "^1.0.0" - } - }, - "is-bigint": { - "version": "1.0.2", - "bundled": true - }, - "is-boolean-object": { "version": "1.1.1", - "bundled": true, "requires": { - "call-bind": "^1.0.2" + "call-bind": "^1.0.2", + "has-tostringtag": "^1.0.0" } }, "is-callable": { - "version": "1.2.3", - "bundled": true - }, - "is-date-object": { - "version": "1.0.4", - "bundled": true + "version": "1.2.7" }, "is-generator-function": { - "version": "1.0.9", - "bundled": true + "version": "1.0.10", + "requires": { + "has-tostringtag": "^1.0.0" + } }, "is-nan": { "version": "1.3.2", - "bundled": true, "requires": { "call-bind": "^1.0.0", "define-properties": "^1.1.3" } }, - "is-negative-zero": { - "version": "2.0.1", - "bundled": true - }, - "is-number-object": { - "version": "1.0.5", - "bundled": true - }, - "is-regex": { - "version": "1.1.3", - "bundled": true, - "requires": { - "call-bind": "^1.0.2", - "has-symbols": "^1.0.2" - } - }, - "is-string": { - "version": "1.0.6", - "bundled": true - }, - "is-symbol": { - "version": "1.0.4", - "bundled": true, - "requires": { - "has-symbols": "^1.0.2" - } - }, "is-typed-array": { - "version": "1.1.5", - "bundled": true, + "version": "1.1.12", "requires": { - "available-typed-arrays": "^1.0.2", - "call-bind": "^1.0.2", - "es-abstract": "^1.18.0-next.2", - "foreach": "^2.0.5", - "has-symbols": "^1.0.1" + "which-typed-array": "^1.1.11" } }, + "isarray": { + "version": "1.0.0" + }, "md5.js": { "version": "1.3.5", - "bundled": true, "requires": { "hash-base": "^3.0.0", "inherits": "^2.0.1", @@ -3614,78 +3453,75 @@ }, "miller-rabin": { "version": "4.0.1", - "bundled": true, "requires": { "bn.js": "^4.0.0", "brorand": "^1.0.1" }, "dependencies": { "bn.js": { - "version": "4.12.0", - "bundled": true + "version": "4.12.0" } } }, "minimalistic-assert": { - "version": "1.0.1", - "bundled": true + "version": "1.0.1" }, "minimalistic-crypto-utils": { - "version": "1.0.1", - "bundled": true + "version": "1.0.1" }, "object-inspect": { - "version": "1.10.3", - "bundled": true + "version": "1.13.1" }, "object-is": { "version": "1.1.5", - "bundled": true, "requires": { "call-bind": "^1.0.2", "define-properties": "^1.1.3" } }, "object-keys": { - "version": "1.1.1", - "bundled": true + "version": "1.1.1" }, "object.assign": { - "version": "4.1.2", - "bundled": true, + "version": "4.1.4", "requires": { - "call-bind": "^1.0.0", - "define-properties": "^1.1.3", - "has-symbols": "^1.0.1", + "call-bind": "^1.0.2", + "define-properties": "^1.1.4", + "has-symbols": "^1.0.3", "object-keys": "^1.1.1" } }, "os-browserify": { - "version": "0.3.0", - "bundled": true + "version": "0.3.0" }, "pako": { - "version": "1.0.11", - "bundled": true + "version": "1.0.11" }, "parse-asn1": { - "version": "5.1.6", - "bundled": true, + "version": "5.1.7", "requires": { - "asn1.js": "^5.2.0", - "browserify-aes": "^1.0.0", - "evp_bytestokey": "^1.0.0", - "pbkdf2": "^3.0.3", - "safe-buffer": "^5.1.1" + "asn1.js": "^4.10.1", + "browserify-aes": "^1.2.0", + "evp_bytestokey": "^1.0.3", + "hash-base": "~3.0", + "pbkdf2": "^3.1.2", + "safe-buffer": "^5.2.1" + }, + "dependencies": { + "hash-base": { + "version": "3.0.4", + "requires": { + "inherits": "^2.0.1", + "safe-buffer": "^5.0.1" + } + } } }, "path-browserify": { - "version": "1.0.1", - "bundled": true + "version": "1.0.1" }, "pbkdf2": { "version": "3.1.2", - "bundled": true, "requires": { "create-hash": "^1.1.2", "create-hmac": "^1.1.4", @@ -3695,12 +3531,13 @@ } }, "process": { - "version": "0.11.10", - "bundled": true + "version": "0.11.10" + }, + "process-nextick-args": { + "version": "2.0.1" }, "public-encrypt": { "version": "4.0.3", - "bundled": true, "requires": { "bn.js": "^4.1.0", "browserify-rsa": "^4.0.0", @@ -3711,41 +3548,37 @@ }, "dependencies": { "bn.js": { - "version": "4.12.0", - "bundled": true + "version": "4.12.0" } } }, "punycode": { - "version": "1.4.1", - "bundled": true + "version": "1.4.1" }, - "querystring": { - "version": "0.2.0", - "bundled": true + "qs": { + "version": "6.11.2", + "requires": { + "side-channel": "^1.0.4" + } }, "querystring-es3": { - "version": "0.2.1", - "bundled": true + "version": "0.2.1" }, "randombytes": { "version": "2.1.0", - "bundled": true, "requires": { "safe-buffer": "^5.1.0" } }, "randomfill": { "version": "1.0.4", - "bundled": true, "requires": { "randombytes": "^2.0.5", "safe-buffer": "^5.1.0" } }, "readable-stream": { - "version": "3.6.0", - "bundled": true, + "version": "3.6.2", "requires": { "inherits": "^2.0.3", "string_decoder": "^1.1.1", @@ -3754,35 +3587,43 @@ }, "ripemd160": { "version": "2.0.2", - "bundled": true, "requires": { "hash-base": "^3.0.0", "inherits": "^2.0.1" } }, "safe-buffer": { - "version": "5.2.1", - "bundled": true + "version": "5.2.1" }, - "safer-buffer": { - "version": "2.1.2", - "bundled": true + "set-function-length": { + "version": "1.1.1", + "requires": { + "define-data-property": "^1.1.1", + "get-intrinsic": "^1.2.1", + "gopd": "^1.0.1", + "has-property-descriptors": "^1.0.0" + } }, "setimmediate": { - "version": "1.0.5", - "bundled": true + "version": "1.0.5" }, "sha.js": { "version": "2.4.11", - "bundled": true, "requires": { "inherits": "^2.0.1", "safe-buffer": "^5.0.1" } }, + "side-channel": { + "version": "1.0.4", + "requires": { + "call-bind": "^1.0.0", + "get-intrinsic": "^1.0.2", + "object-inspect": "^1.9.0" + } + }, "stream-browserify": { "version": "3.0.0", - "bundled": true, "requires": { "inherits": "~2.0.4", "readable-stream": "^3.5.0" @@ -3790,7 +3631,6 @@ }, "stream-http": { "version": "3.2.0", - "bundled": true, "requires": { "builtin-status-codes": "^3.0.0", "inherits": "^2.0.4", @@ -3798,111 +3638,56 @@ "xtend": "^4.0.2" } }, - "string.prototype.trimend": { - "version": "1.0.4", - "bundled": true, - "requires": { - "call-bind": "^1.0.2", - "define-properties": "^1.1.3" - } - }, - "string.prototype.trimstart": { - "version": "1.0.4", - "bundled": true, - "requires": { - "call-bind": "^1.0.2", - "define-properties": "^1.1.3" - } - }, "string_decoder": { "version": "1.3.0", - "bundled": true, "requires": { "safe-buffer": "~5.2.0" } }, "timers-browserify": { "version": "2.0.12", - "bundled": true, "requires": { "setimmediate": "^1.0.4" } }, "tty-browserify": { - "version": "0.0.1", - "bundled": true - }, - "unbox-primitive": { - "version": "1.0.1", - "bundled": true, - "requires": { - "function-bind": "^1.1.1", - "has-bigints": "^1.0.1", - "has-symbols": "^1.0.2", - "which-boxed-primitive": "^1.0.2" - } + "version": "0.0.1" }, "url": { - "version": "0.11.0", - "bundled": true, + "version": "0.11.3", "requires": { - "punycode": "1.3.2", - "querystring": "0.2.0" - }, - "dependencies": { - "punycode": { - "version": "1.3.2", - "bundled": true - } + "punycode": "^1.4.1", + "qs": "^6.11.2" } }, "util": { - "version": "0.12.4", - "bundled": true, + "version": "0.12.5", "requires": { "inherits": "^2.0.3", "is-arguments": "^1.0.4", "is-generator-function": "^1.0.7", "is-typed-array": "^1.1.3", - "safe-buffer": "^5.1.2", "which-typed-array": "^1.1.2" } }, "util-deprecate": { - "version": "1.0.2", - "bundled": true + "version": "1.0.2" }, "vm-browserify": { - "version": "1.1.2", - "bundled": true - }, - "which-boxed-primitive": { - "version": "1.0.2", - "bundled": true, - "requires": { - "is-bigint": "^1.0.1", - "is-boolean-object": "^1.1.0", - "is-number-object": "^1.0.4", - "is-string": "^1.0.5", - "is-symbol": "^1.0.3" - } + "version": "1.1.2" }, "which-typed-array": { - "version": "1.1.4", - "bundled": true, + "version": "1.1.13", "requires": { - "available-typed-arrays": "^1.0.2", - "call-bind": "^1.0.0", - "es-abstract": "^1.18.0-next.1", - "foreach": "^2.0.5", - "function-bind": "^1.1.1", - "has-symbols": "^1.0.1", - "is-typed-array": "^1.1.3" + "available-typed-arrays": "^1.0.5", + "call-bind": "^1.0.4", + "for-each": "^0.3.3", + "gopd": "^1.0.1", + "has-tostringtag": "^1.0.0" } }, "xtend": { - "version": "4.0.2", - "bundled": true + "version": "4.0.2" } } }, @@ -3991,9 +3776,9 @@ } }, "node-releases": { - "version": "2.0.13", - "resolved": "https://registry.npmjs.org/node-releases/-/node-releases-2.0.13.tgz", - "integrity": "sha512-uYr7J37ae/ORWdZeQ1xxMJe3NtdmqMC/JZK+geofDrkLUApKRHPd18/TxtBOJ4A0/+uUIliorNrfYV6s1b02eQ==", + "version": "2.0.18", + "resolved": "https://registry.npmjs.org/node-releases/-/node-releases-2.0.18.tgz", + "integrity": "sha512-d9VeXT4SJ7ZeOqGX6R5EM022wpL+eWPooLI+5UpWn2jCT1aosUQEhQP214x33Wkwx3JQMvIm+tIoVOdodFS40g==", "dev": true }, "node-uuid": { @@ -4036,18 +3821,22 @@ "yargs": "^15.0.2" }, "dependencies": { - "glob": { - "version": "7.2.3", - "resolved": "https://registry.npmjs.org/glob/-/glob-7.2.3.tgz", - "integrity": "sha512-nFR0zLpU2YCaRxwoCJvL6UvCH2JFyFVIvwTLsIf21AuHlMskA1hhTdk+LlYJtOlYt9v6dvszD2BGRqBL+iQK9Q==", + "convert-source-map": { + "version": "1.9.0", + "resolved": "https://registry.npmjs.org/convert-source-map/-/convert-source-map-1.9.0.tgz", + "integrity": "sha512-ASFBup0Mz1uyiIjANan1jzLQami9z1PoYSZCiiYW2FczPbenXc45FZdBZLzOT+r6+iciuEModtmCti+hjaAk0A==", + "dev": true + }, + "istanbul-lib-instrument": { + "version": "4.0.3", + "resolved": "https://registry.npmjs.org/istanbul-lib-instrument/-/istanbul-lib-instrument-4.0.3.tgz", + "integrity": "sha512-BXgQl9kf4WTCPCCpmFGoJkz/+uhvm7h7PFKUYxh7qarQd3ER33vHG//qaE8eN25l07YqZPpHXU9I09l/RD5aGQ==", "dev": true, "requires": { - "fs.realpath": "^1.0.0", - "inflight": "^1.0.4", - "inherits": "2", - "minimatch": "^3.1.1", - "once": "^1.3.0", - "path-is-absolute": "^1.0.0" + "@babel/core": "^7.7.5", + "@istanbuljs/schema": "^0.1.2", + "istanbul-lib-coverage": "^3.0.0", + "semver": "^6.3.0" } } } @@ -4276,9 +4065,9 @@ "dev": true }, "picocolors": { - "version": "1.0.0", - "resolved": "https://registry.npmjs.org/picocolors/-/picocolors-1.0.0.tgz", - "integrity": "sha512-1fygroTLlHu66zi26VoTDv8yRgm0Fccecssto+MhsZ0D/DGW2sm8E8AjW7NU5VVTRt5GxbeZ5qBuJr+HyLYkjQ==", + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/picocolors/-/picocolors-1.0.1.tgz", + "integrity": "sha512-anP1Z8qwhkbmu7MFP5iTt+wQKXgwzf7zTyGlcdzabySa9vd0Xt392U0rVmz9poOaBj0uHJKyyo9/upk0HrEQew==", "dev": true }, "pify": { @@ -4767,17 +4556,6 @@ "rimraf": "^3.0.0", "signal-exit": "^3.0.2", "which": "^2.0.1" - }, - "dependencies": { - "which": { - "version": "2.0.2", - "resolved": "https://registry.npmjs.org/which/-/which-2.0.2.tgz", - "integrity": "sha512-BLI3Tl1TW3Pvl70l3yq3Y64i+awpwXqsGBYWkkqMtnbXgrMD+yj7rhW0kuEDxzJaYXGjEW5ogapKNMEKNMjibA==", - "dev": true, - "requires": { - "isexe": "^2.0.0" - } - } } }, "sprintf-js": { @@ -4964,22 +4742,6 @@ "@istanbuljs/schema": "^0.1.2", "glob": "^7.1.4", "minimatch": "^3.0.4" - }, - "dependencies": { - "glob": { - "version": "7.2.3", - "resolved": "https://registry.npmjs.org/glob/-/glob-7.2.3.tgz", - "integrity": "sha512-nFR0zLpU2YCaRxwoCJvL6UvCH2JFyFVIvwTLsIf21AuHlMskA1hhTdk+LlYJtOlYt9v6dvszD2BGRqBL+iQK9Q==", - "dev": true, - "requires": { - "fs.realpath": "^1.0.0", - "inflight": "^1.0.4", - "inherits": "2", - "minimatch": "^3.1.1", - "once": "^1.3.0", - "path-is-absolute": "^1.0.0" - } - } } }, "text-table": { @@ -5067,9 +4829,9 @@ "optional": true }, "type-detect": { - "version": "4.0.8", - "resolved": "https://registry.npmjs.org/type-detect/-/type-detect-4.0.8.tgz", - "integrity": "sha512-0fr/mIH1dlO+x7TlcMy+bIDqKPsw/70tVyeHW787goQjhmqaZe10uwLujubK9q9Lg6Fiho1KUKDYz0Z7k7g5/g==", + "version": "4.1.0", + "resolved": "https://registry.npmjs.org/type-detect/-/type-detect-4.1.0.tgz", + "integrity": "sha512-Acylog8/luQ8L7il+geoSxhEkazvkslg7PSNKOX59mbB9cOveP5aq9h74Y7YU8yDpJwetzQQrfIwtf4Wp4LKcw==", "dev": true }, "type-fest": { @@ -5170,19 +4932,26 @@ "through": "^2.3.8" } }, + "undici-types": { + "version": "6.19.8", + "resolved": "https://registry.npmjs.org/undici-types/-/undici-types-6.19.8.tgz", + "integrity": "sha512-ve2KP6f/JnbPBFyobGHuerC9g1FYGn/F8n1LWTwNxCEzd6IfqTwUQcNXgEtmmQ6DlRrC1hrSrBnCZPokRrDHjw==", + "dev": true, + "optional": true + }, "unpipe": { "version": "1.0.0", "resolved": "https://registry.npmjs.org/unpipe/-/unpipe-1.0.0.tgz", "integrity": "sha512-pjy2bYhSsufwWlKwPc+l3cN7+wuJlK6uz0YdJEOlQDbl6jo/YlPi4mb8agUkVC8BF7V8NuzeyPNqRksA3hztKQ==" }, "update-browserslist-db": { - "version": "1.0.11", - "resolved": "https://registry.npmjs.org/update-browserslist-db/-/update-browserslist-db-1.0.11.tgz", - "integrity": "sha512-dCwEFf0/oT85M1fHBg4F0jtLwJrutGoHSQXCh7u4o2t1drG+c0a9Flnqww6XUKSfQMPpJBRjU8d4RXB09qtvaA==", + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/update-browserslist-db/-/update-browserslist-db-1.1.0.tgz", + "integrity": "sha512-EdRAaAyk2cUE1wOf2DkEhzxqOQvFOoRJFNS6NeyJ01Gp2beMRpBAINjM2iDXE3KCuKhwnvHIQCJm6ThL2Z+HzQ==", "dev": true, "requires": { - "escalade": "^3.1.1", - "picocolors": "^1.0.0" + "escalade": "^3.1.2", + "picocolors": "^1.0.1" } }, "uri-js": { @@ -5215,12 +4984,6 @@ "resolved": "https://registry.npmjs.org/utils-merge/-/utils-merge-1.0.1.tgz", "integrity": "sha512-pMZTvIkT1d+TFGvDOqodOclx0QWkkgi6Tdoa8gC8ffGAAqz9pzPTZWAybbsHHoED/ztMtkv/VoYTYyShUn81hA==" }, - "uuid": { - "version": "8.3.2", - "resolved": "https://registry.npmjs.org/uuid/-/uuid-8.3.2.tgz", - "integrity": "sha512-+NYs2QeMWy+GWFOEm9xnn6HCDp0l7QBD7ml8zLUmJ+93Q5NF0NocErnwkTkXVFNiX3/fpC6afS8Dhb/gz7R7eg==", - "dev": true - }, "vary": { "version": "1.1.2", "resolved": "https://registry.npmjs.org/vary/-/vary-1.1.2.tgz", @@ -5248,6 +5011,15 @@ "webidl-conversions": "^3.0.0" } }, + "which": { + "version": "2.0.2", + "resolved": "https://registry.npmjs.org/which/-/which-2.0.2.tgz", + "integrity": "sha512-BLI3Tl1TW3Pvl70l3yq3Y64i+awpwXqsGBYWkkqMtnbXgrMD+yj7rhW0kuEDxzJaYXGjEW5ogapKNMEKNMjibA==", + "dev": true, + "requires": { + "isexe": "^2.0.0" + } + }, "which-boxed-primitive": { "version": "1.0.2", "resolved": "https://registry.npmjs.org/which-boxed-primitive/-/which-boxed-primitive-1.0.2.tgz", diff --git a/testapp/package.json b/testapp/package.json index b1d84ef2..a40f65fa 100644 --- a/testapp/package.json +++ b/testapp/package.json @@ -11,14 +11,14 @@ "lint:fix": "standard --fix ../" }, "dependencies": { - "@babel/runtime": "7.23.6", - "meteor-node-stubs": "1.2.7", + "@babel/runtime": "7.25.6", + "meteor-node-stubs": "1.2.9", "yuidocjs": "0.10.2" }, "devDependencies": { "babel-plugin-istanbul": "^6.1.1", - "chai": "^4.3.10", - "chai-as-promised": "^7.1.1", + "chai": "^4.5.0", + "chai-as-promised": "^7.1.2", "nyc": "^15.1.0", "puppeteer": "^19.11.1", "standard": "^17.1.0" From c9334f33c5fad928592c8b037c0e0745a432a251 Mon Sep 17 00:00:00 2001 From: Jan Dvorak Date: Thu, 29 Aug 2024 12:34:03 +0200 Subject: [PATCH 34/45] Published alanning:roles@4.0.0-rc.3 --- .versions | 124 +++++++++++++++++++++++++++-------------------------- package.js | 6 +-- 2 files changed, 66 insertions(+), 64 deletions(-) diff --git a/.versions b/.versions index bf9c9e5c..bdf8de4a 100644 --- a/.versions +++ b/.versions @@ -1,62 +1,64 @@ -accounts-base@2.2.11 -alanning:roles@4.0.0-rc.2 -allow-deny@1.1.1 -babel-compiler@7.10.5 -babel-runtime@1.5.1 -base64@1.0.12 -binary-heap@1.0.11 -boilerplate-generator@1.7.2 -callback-hook@1.5.1 -check@1.4.1 -ddp@1.4.1 -ddp-client@2.6.2 -ddp-common@1.4.1 -ddp-rate-limiter@1.2.1 -ddp-server@2.7.1 -diff-sequence@1.1.2 -dynamic-import@0.7.3 -ecmascript@0.16.8 -ecmascript-runtime@0.8.1 -ecmascript-runtime-client@0.12.1 -ecmascript-runtime-server@0.11.0 -ejson@1.1.3 -fetch@0.1.4 -geojson-utils@1.0.11 -http@2.0.0 -id-map@1.1.1 -inter-process-messaging@0.1.1 -lmieulet:meteor-coverage@4.1.0 -lmieulet:meteor-legacy-coverage@0.1.0 -local-test:alanning:roles@4.0.0-rc.2 -localstorage@1.2.0 -logging@1.3.4 -meteor@1.11.5 -meteortesting:browser-tests@1.4.2 -meteortesting:mocha@2.1.0 -meteortesting:mocha-core@8.0.1 -minimongo@1.9.4 -modern-browsers@0.1.10 -modules@0.20.0 -modules-runtime@0.13.1 -mongo@1.16.10 -mongo-decimal@0.1.3 -mongo-dev-server@1.1.0 -mongo-id@1.0.8 -npm-mongo@4.17.2 -ordered-dict@1.1.0 -promise@0.12.2 -random@1.2.1 -rate-limit@1.1.1 -react-fast-refresh@0.2.8 -reactive-var@1.0.12 -reload@1.3.1 -retry@1.1.0 -routepolicy@1.1.1 -socket-stream-client@0.5.2 -tracker@1.3.3 -typescript@4.9.5 -underscore@1.6.1 -url@1.3.2 -webapp@1.13.8 -webapp-hashing@1.1.1 +accounts-base@3.0.1 +alanning:roles@4.0.0-rc.3 +allow-deny@2.0.0 +babel-compiler@7.11.0 +babel-runtime@1.5.2 +base64@1.0.13 +binary-heap@1.0.12 +boilerplate-generator@2.0.0 +callback-hook@1.6.0 +check@1.4.2 +core-runtime@1.0.0 +ddp@1.4.2 +ddp-client@3.0.1 +ddp-common@1.4.4 +ddp-rate-limiter@1.2.2 +ddp-server@3.0.1 +diff-sequence@1.1.3 +dynamic-import@0.7.4 +ecmascript@0.16.9 +ecmascript-runtime@0.8.2 +ecmascript-runtime-client@0.12.2 +ecmascript-runtime-server@0.11.1 +ejson@1.1.4 +facts-base@1.0.2 +fetch@0.1.5 +geojson-utils@1.0.12 +http@1.4.4 +id-map@1.2.0 +inter-process-messaging@0.1.2 +lmieulet:meteor-coverage@5.0.0 +lmieulet:meteor-legacy-coverage@0.4.0 +local-test:alanning:roles@4.0.0-rc.3 +localstorage@1.2.1 +logging@1.3.5 +meteor@2.0.1 +meteortesting:browser-tests@1.7.0 +meteortesting:mocha@3.2.0 +meteortesting:mocha-core@8.2.0 +minimongo@2.0.1 +modern-browsers@0.1.11 +modules@0.20.1 +modules-runtime@0.13.2 +mongo@2.0.1 +mongo-decimal@0.1.4-beta300.7 +mongo-dev-server@1.1.1 +mongo-id@1.0.9 +npm-mongo@4.17.4 +ordered-dict@1.2.0 +promise@1.0.0 +random@1.2.2 +rate-limit@1.1.2 +react-fast-refresh@0.2.9 +reactive-var@1.0.13 +reload@1.3.2 +retry@1.1.1 +routepolicy@1.1.2 +socket-stream-client@0.5.3 +tracker@1.3.4 +typescript@5.4.3 +underscore@1.6.4 +url@1.3.3 +webapp@2.0.1 +webapp-hashing@1.1.2 zodern:types@1.0.13 diff --git a/package.js b/package.js index b9c3e6de..981a0dd8 100644 --- a/package.js +++ b/package.js @@ -2,7 +2,7 @@ Package.describe({ summary: 'Authorization package for Meteor', - version: '4.0.0-rc.2', + version: '4.0.0-rc.3', git: 'https://github.com/Meteor-Community-Packages/meteor-roles.git', name: 'alanning:roles' }) @@ -41,8 +41,8 @@ Package.onTest(function (api) { // Add code coverage api.use([ 'lmieulet:meteor-legacy-coverage', - 'lmieulet:meteor-coverage@4.1.0', - 'meteortesting:mocha@2.1.0' + 'lmieulet:meteor-coverage@4.1.0 || 5.0.0', + 'meteortesting:mocha@2.1.0 || 3.0.0' ]) api.versionsFrom(['2.8.1', '3.0']) From 93686e574faee230fcd7caef8c4d9287d22b0ed5 Mon Sep 17 00:00:00 2001 From: Jan Dvorak Date: Fri, 30 Aug 2024 14:56:04 +0200 Subject: [PATCH 35/45] Update meteortesting:mocha version number --- package.js | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/package.js b/package.js index 981a0dd8..7615b7ec 100644 --- a/package.js +++ b/package.js @@ -42,7 +42,7 @@ Package.onTest(function (api) { api.use([ 'lmieulet:meteor-legacy-coverage', 'lmieulet:meteor-coverage@4.1.0 || 5.0.0', - 'meteortesting:mocha@2.1.0 || 3.0.0' + 'meteortesting:mocha@2.1.0 || 3.2.0' ]) api.versionsFrom(['2.8.1', '3.0']) From d136e8c1d8495338af016cd4a34d99fc24ddcc64 Mon Sep 17 00:00:00 2001 From: Jan Dvorak Date: Sat, 31 Aug 2024 15:03:42 +0200 Subject: [PATCH 36/45] Split testing suite --- .github/workflows/testsuite.yml | 41 +- {testapp => testapp2}/.coverage.json | 0 {testapp => testapp2}/.gitignore | 0 .../.meteor/.finished-upgraders | 0 {testapp => testapp2}/.meteor/.gitignore | 0 {testapp => testapp2}/.meteor/.id | 0 {testapp => testapp2}/.meteor/packages | 0 {testapp => testapp2}/.meteor/platforms | 0 {testapp => testapp2}/.meteor/release | 0 {testapp => testapp2}/.meteor/versions | 0 {testapp => testapp2}/package-lock.json | 0 {testapp => testapp2}/package.json | 5 +- testapp3/.gitignore | 1 + testapp3/.meteor/.finished-upgraders | 19 + testapp3/.meteor/.gitignore | 1 + testapp3/.meteor/.id | 7 + testapp3/.meteor/packages | 19 + testapp3/.meteor/platforms | 2 + testapp3/.meteor/release | 1 + testapp3/.meteor/versions | 70 + testapp3/package-lock.json | 6883 +++++++++++++++++ testapp3/package.json | 42 + 22 files changed, 7083 insertions(+), 8 deletions(-) rename {testapp => testapp2}/.coverage.json (100%) rename {testapp => testapp2}/.gitignore (100%) rename {testapp => testapp2}/.meteor/.finished-upgraders (100%) rename {testapp => testapp2}/.meteor/.gitignore (100%) rename {testapp => testapp2}/.meteor/.id (100%) rename {testapp => testapp2}/.meteor/packages (100%) rename {testapp => testapp2}/.meteor/platforms (100%) rename {testapp => testapp2}/.meteor/release (100%) rename {testapp => testapp2}/.meteor/versions (100%) rename {testapp => testapp2}/package-lock.json (100%) rename {testapp => testapp2}/package.json (95%) create mode 100644 testapp3/.gitignore create mode 100644 testapp3/.meteor/.finished-upgraders create mode 100644 testapp3/.meteor/.gitignore create mode 100644 testapp3/.meteor/.id create mode 100644 testapp3/.meteor/packages create mode 100644 testapp3/.meteor/platforms create mode 100644 testapp3/.meteor/release create mode 100644 testapp3/.meteor/versions create mode 100644 testapp3/package-lock.json create mode 100644 testapp3/package.json diff --git a/.github/workflows/testsuite.yml b/.github/workflows/testsuite.yml index 3bee1b70..460cd134 100644 --- a/.github/workflows/testsuite.yml +++ b/.github/workflows/testsuite.yml @@ -29,17 +29,46 @@ jobs: - run: cd testapp && npm ci && npm run setup && npm run lint - test: - name: Meteor package tests + test2: + name: Meteor package tests 2.16 needs: [lint] runs-on: ubuntu-latest strategy: matrix: meteorRelease: - - '2.8.1' - '2.16' - - '3.0' - # Latest version + steps: + - name: Checkout code + uses: actions/checkout@v4 + + - name: Install Node.js + uses: actions/setup-node@v4 + with: + node-version: 14 + + - name: Setup meteor ${{ matrix.meteorRelease }} + uses: meteorengineer/setup-meteor@v1 + with: + meteor-release: ${{ matrix.meteorRelease }} + + - name: cache dependencies + uses: actions/cache@v3 + with: + path: ~/.npm + key: ${{ runner.os }}-node-14-${{ hashFiles('**/package-lock.json') }} + restore-keys: | + ${{ runner.os }}-node-14- + + - run: cd testapp2 && npm ci && npm run setup && npm run test + + test3: + name: Meteor package tests 3.0.2 + needs: [lint] + runs-on: ubuntu-latest + strategy: + matrix: + meteorRelease: + - '3.0.2' steps: - name: Checkout code uses: actions/checkout@v4 @@ -62,4 +91,4 @@ jobs: restore-keys: | ${{ runner.os }}-node-20- - - run: cd testapp && npm ci && npm run setup && npm run test + - run: cd testapp3 && npm ci && npm run setup && npm run test diff --git a/testapp/.coverage.json b/testapp2/.coverage.json similarity index 100% rename from testapp/.coverage.json rename to testapp2/.coverage.json diff --git a/testapp/.gitignore b/testapp2/.gitignore similarity index 100% rename from testapp/.gitignore rename to testapp2/.gitignore diff --git a/testapp/.meteor/.finished-upgraders b/testapp2/.meteor/.finished-upgraders similarity index 100% rename from testapp/.meteor/.finished-upgraders rename to testapp2/.meteor/.finished-upgraders diff --git a/testapp/.meteor/.gitignore b/testapp2/.meteor/.gitignore similarity index 100% rename from testapp/.meteor/.gitignore rename to testapp2/.meteor/.gitignore diff --git a/testapp/.meteor/.id b/testapp2/.meteor/.id similarity index 100% rename from testapp/.meteor/.id rename to testapp2/.meteor/.id diff --git a/testapp/.meteor/packages b/testapp2/.meteor/packages similarity index 100% rename from testapp/.meteor/packages rename to testapp2/.meteor/packages diff --git a/testapp/.meteor/platforms b/testapp2/.meteor/platforms similarity index 100% rename from testapp/.meteor/platforms rename to testapp2/.meteor/platforms diff --git a/testapp/.meteor/release b/testapp2/.meteor/release similarity index 100% rename from testapp/.meteor/release rename to testapp2/.meteor/release diff --git a/testapp/.meteor/versions b/testapp2/.meteor/versions similarity index 100% rename from testapp/.meteor/versions rename to testapp2/.meteor/versions diff --git a/testapp/package-lock.json b/testapp2/package-lock.json similarity index 100% rename from testapp/package-lock.json rename to testapp2/package-lock.json diff --git a/testapp/package.json b/testapp2/package.json similarity index 95% rename from testapp/package.json rename to testapp2/package.json index a40f65fa..15d06274 100644 --- a/testapp/package.json +++ b/testapp2/package.json @@ -1,5 +1,5 @@ { - "name": "testapp", + "name": "testapp2", "private": true, "scripts": { "setup": "mkdir -p packages && ln -sfn ../../ ./packages/meteor-roles", @@ -36,7 +36,8 @@ "ignore": [ "**/.meteor/", "**/examples/", - "**/testapp" + "**/testapp2", + "**/testapp3" ] } } diff --git a/testapp3/.gitignore b/testapp3/.gitignore new file mode 100644 index 00000000..40b878db --- /dev/null +++ b/testapp3/.gitignore @@ -0,0 +1 @@ +node_modules/ \ No newline at end of file diff --git a/testapp3/.meteor/.finished-upgraders b/testapp3/.meteor/.finished-upgraders new file mode 100644 index 00000000..c07b6ff7 --- /dev/null +++ b/testapp3/.meteor/.finished-upgraders @@ -0,0 +1,19 @@ +# This file contains information which helps Meteor properly upgrade your +# app when you run 'meteor update'. You should check it into version control +# with your project. + +notices-for-0.9.0 +notices-for-0.9.1 +0.9.4-platform-file +notices-for-facebook-graph-api-2 +1.2.0-standard-minifiers-package +1.2.0-meteor-platform-split +1.2.0-cordova-changes +1.2.0-breaking-changes +1.3.0-split-minifiers-package +1.4.0-remove-old-dev-bundle-link +1.4.1-add-shell-server-package +1.4.3-split-account-service-packages +1.5-add-dynamic-import-package +1.7-split-underscore-from-meteor-base +1.8.3-split-jquery-from-blaze diff --git a/testapp3/.meteor/.gitignore b/testapp3/.meteor/.gitignore new file mode 100644 index 00000000..40830374 --- /dev/null +++ b/testapp3/.meteor/.gitignore @@ -0,0 +1 @@ +local diff --git a/testapp3/.meteor/.id b/testapp3/.meteor/.id new file mode 100644 index 00000000..8dc86b34 --- /dev/null +++ b/testapp3/.meteor/.id @@ -0,0 +1,7 @@ +# This file contains a token that is unique to your project. +# Check it into your repository along with the rest of this directory. +# It can be used for purposes such as: +# - ensuring you don't accidentally deploy one app on top of another +# - providing package authors with aggregated statistics + +rcbgjlqvg8sn.fgbt2fn0eab9 diff --git a/testapp3/.meteor/packages b/testapp3/.meteor/packages new file mode 100644 index 00000000..5ad4d989 --- /dev/null +++ b/testapp3/.meteor/packages @@ -0,0 +1,19 @@ +# Meteor packages used by this project, one per line. +# Check this file (and the other files in this directory) into your repository. +# +# 'meteor add' and 'meteor remove' will edit this file for you, +# but you can also edit it by hand. + +meteor-base@1.5.2 # Packages every Meteor app needs to have +mobile-experience@1.1.2 # Packages for a great mobile UX +mongo@2.0.1 # The database Meteor supports right now +static-html@1.3.3 # Define static page content in .html files +reactive-var@1.0.13 # Reactive variable for tracker +tracker@1.3.4 # Meteor's client-side reactive programming library + +standard-minifier-css@1.9.3 # CSS minifier run for production mode +standard-minifier-js@3.0.0 # JS minifier run for production mode +es5-shim@4.8.1 # ECMAScript 5 compatibility for older browsers +ecmascript@0.16.9 # Enable ECMAScript2015+ syntax in app code +typescript@5.4.3 # Enable TypeScript syntax in .ts and .tsx modules +shell-server@0.6.0 # Server-side component of the `meteor shell` command diff --git a/testapp3/.meteor/platforms b/testapp3/.meteor/platforms new file mode 100644 index 00000000..efeba1b5 --- /dev/null +++ b/testapp3/.meteor/platforms @@ -0,0 +1,2 @@ +server +browser diff --git a/testapp3/.meteor/release b/testapp3/.meteor/release new file mode 100644 index 00000000..8b5075d4 --- /dev/null +++ b/testapp3/.meteor/release @@ -0,0 +1 @@ +METEOR@3.0.2 diff --git a/testapp3/.meteor/versions b/testapp3/.meteor/versions new file mode 100644 index 00000000..272529f7 --- /dev/null +++ b/testapp3/.meteor/versions @@ -0,0 +1,70 @@ +allow-deny@2.0.0 +autoupdate@2.0.0 +babel-compiler@7.11.0 +babel-runtime@1.5.2 +base64@1.0.13 +binary-heap@1.0.12 +blaze-tools@2.0.0 +boilerplate-generator@2.0.0 +caching-compiler@2.0.0 +caching-html-compiler@2.0.0 +callback-hook@1.6.0 +check@1.4.2 +core-runtime@1.0.0 +ddp@1.4.2 +ddp-client@3.0.1 +ddp-common@1.4.4 +ddp-server@3.0.1 +diff-sequence@1.1.3 +dynamic-import@0.7.4 +ecmascript@0.16.9 +ecmascript-runtime@0.8.2 +ecmascript-runtime-client@0.12.2 +ecmascript-runtime-server@0.11.1 +ejson@1.1.4 +es5-shim@4.8.1 +facts-base@1.0.2 +fetch@0.1.5 +geojson-utils@1.0.12 +hot-code-push@1.0.5 +html-tools@2.0.0 +htmljs@2.0.1 +id-map@1.2.0 +inter-process-messaging@0.1.2 +launch-screen@2.0.1 +logging@1.3.5 +meteor@2.0.1 +meteor-base@1.5.2 +minifier-css@2.0.0 +minifier-js@3.0.0 +minimongo@2.0.1 +mobile-experience@1.1.2 +mobile-status-bar@1.1.1 +modern-browsers@0.1.11 +modules@0.20.1 +modules-runtime@0.13.2 +mongo@2.0.1 +mongo-decimal@0.1.4-beta300.7 +mongo-dev-server@1.1.1 +mongo-id@1.0.9 +npm-mongo@4.17.4 +ordered-dict@1.2.0 +promise@1.0.0 +random@1.2.2 +react-fast-refresh@0.2.9 +reactive-var@1.0.13 +reload@1.3.2 +retry@1.1.1 +routepolicy@1.1.2 +shell-server@0.6.0 +socket-stream-client@0.5.3 +spacebars-compiler@2.0.0 +standard-minifier-css@1.9.3 +standard-minifier-js@3.0.0 +static-html@1.3.3 +templating-tools@2.0.0 +tracker@1.3.4 +typescript@5.4.3 +underscore@1.6.4 +webapp@2.0.1 +webapp-hashing@1.1.2 diff --git a/testapp3/package-lock.json b/testapp3/package-lock.json new file mode 100644 index 00000000..5ad5fe20 --- /dev/null +++ b/testapp3/package-lock.json @@ -0,0 +1,6883 @@ +{ + "name": "testapp3", + "lockfileVersion": 3, + "requires": true, + "packages": { + "": { + "name": "testapp3", + "dependencies": { + "@babel/runtime": "^7.25.6", + "meteor-node-stubs": "^1.2.9" + }, + "devDependencies": { + "babel-plugin-istanbul": "^6.1.1", + "chai": "^4.5.0", + "chai-as-promised": "^7.1.2", + "nyc": "^15.1.0", + "puppeteer": "^19.11.1", + "standard": "^17.1.0" + } + }, + "node_modules/@ampproject/remapping": { + "version": "2.3.0", + "resolved": "https://registry.npmjs.org/@ampproject/remapping/-/remapping-2.3.0.tgz", + "integrity": "sha512-30iZtAPgz+LTIYoeivqYo853f02jBYSd5uGnGpkFV0M3xOt9aN73erkgYAmZU43x4VfqcnLxW9Kpg3R5LC4YYw==", + "dev": true, + "dependencies": { + "@jridgewell/gen-mapping": "^0.3.5", + "@jridgewell/trace-mapping": "^0.3.24" + }, + "engines": { + "node": ">=6.0.0" + } + }, + "node_modules/@babel/code-frame": { + "version": "7.24.7", + "resolved": "https://registry.npmjs.org/@babel/code-frame/-/code-frame-7.24.7.tgz", + "integrity": "sha512-BcYH1CVJBO9tvyIZ2jVeXgSIMvGZ2FDRvDdOIVQyuklNKSsx+eppDEBq/g47Ayw+RqNFE+URvOShmf+f/qwAlA==", + "dev": true, + "dependencies": { + "@babel/highlight": "^7.24.7", + "picocolors": "^1.0.0" + }, + "engines": { + "node": ">=6.9.0" + } + }, + "node_modules/@babel/compat-data": { + "version": "7.25.4", + "resolved": "https://registry.npmjs.org/@babel/compat-data/-/compat-data-7.25.4.tgz", + "integrity": "sha512-+LGRog6RAsCJrrrg/IO6LGmpphNe5DiK30dGjCoxxeGv49B10/3XYGxPsAwrDlMFcFEvdAUavDT8r9k/hSyQqQ==", + "dev": true, + "engines": { + "node": ">=6.9.0" + } + }, + "node_modules/@babel/core": { + "version": "7.25.2", + "resolved": "https://registry.npmjs.org/@babel/core/-/core-7.25.2.tgz", + "integrity": "sha512-BBt3opiCOxUr9euZ5/ro/Xv8/V7yJ5bjYMqG/C1YAo8MIKAnumZalCN+msbci3Pigy4lIQfPUpfMM27HMGaYEA==", + "dev": true, + "dependencies": { + "@ampproject/remapping": "^2.2.0", + "@babel/code-frame": "^7.24.7", + "@babel/generator": "^7.25.0", + "@babel/helper-compilation-targets": "^7.25.2", + "@babel/helper-module-transforms": "^7.25.2", + "@babel/helpers": "^7.25.0", + "@babel/parser": "^7.25.0", + "@babel/template": "^7.25.0", + "@babel/traverse": "^7.25.2", + "@babel/types": "^7.25.2", + "convert-source-map": "^2.0.0", + "debug": "^4.1.0", + "gensync": "^1.0.0-beta.2", + "json5": "^2.2.3", + "semver": "^6.3.1" + }, + "engines": { + "node": ">=6.9.0" + }, + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/babel" + } + }, + "node_modules/@babel/generator": { + "version": "7.25.6", + "resolved": "https://registry.npmjs.org/@babel/generator/-/generator-7.25.6.tgz", + "integrity": "sha512-VPC82gr1seXOpkjAAKoLhP50vx4vGNlF4msF64dSFq1P8RfB+QAuJWGHPXXPc8QyfVWwwB/TNNU4+ayZmHNbZw==", + "dev": true, + "dependencies": { + "@babel/types": "^7.25.6", + "@jridgewell/gen-mapping": "^0.3.5", + "@jridgewell/trace-mapping": "^0.3.25", + "jsesc": "^2.5.1" + }, + "engines": { + "node": ">=6.9.0" + } + }, + "node_modules/@babel/helper-compilation-targets": { + "version": "7.25.2", + "resolved": "https://registry.npmjs.org/@babel/helper-compilation-targets/-/helper-compilation-targets-7.25.2.tgz", + "integrity": "sha512-U2U5LsSaZ7TAt3cfaymQ8WHh0pxvdHoEk6HVpaexxixjyEquMh0L0YNJNM6CTGKMXV1iksi0iZkGw4AcFkPaaw==", + "dev": true, + "dependencies": { + "@babel/compat-data": "^7.25.2", + "@babel/helper-validator-option": "^7.24.8", + "browserslist": "^4.23.1", + "lru-cache": "^5.1.1", + "semver": "^6.3.1" + }, + "engines": { + "node": ">=6.9.0" + } + }, + "node_modules/@babel/helper-module-imports": { + "version": "7.24.7", + "resolved": "https://registry.npmjs.org/@babel/helper-module-imports/-/helper-module-imports-7.24.7.tgz", + "integrity": "sha512-8AyH3C+74cgCVVXow/myrynrAGv+nTVg5vKu2nZph9x7RcRwzmh0VFallJuFTZ9mx6u4eSdXZfcOzSqTUm0HCA==", + "dev": true, + "dependencies": { + "@babel/traverse": "^7.24.7", + "@babel/types": "^7.24.7" + }, + "engines": { + "node": ">=6.9.0" + } + }, + "node_modules/@babel/helper-module-transforms": { + "version": "7.25.2", + "resolved": "https://registry.npmjs.org/@babel/helper-module-transforms/-/helper-module-transforms-7.25.2.tgz", + "integrity": "sha512-BjyRAbix6j/wv83ftcVJmBt72QtHI56C7JXZoG2xATiLpmoC7dpd8WnkikExHDVPpi/3qCmO6WY1EaXOluiecQ==", + "dev": true, + "dependencies": { + "@babel/helper-module-imports": "^7.24.7", + "@babel/helper-simple-access": "^7.24.7", + "@babel/helper-validator-identifier": "^7.24.7", + "@babel/traverse": "^7.25.2" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0" + } + }, + "node_modules/@babel/helper-plugin-utils": { + "version": "7.24.8", + "resolved": "https://registry.npmjs.org/@babel/helper-plugin-utils/-/helper-plugin-utils-7.24.8.tgz", + "integrity": "sha512-FFWx5142D8h2Mgr/iPVGH5G7w6jDn4jUSpZTyDnQO0Yn7Ks2Kuz6Pci8H6MPCoUJegd/UZQ3tAvfLCxQSnWWwg==", + "dev": true, + "engines": { + "node": ">=6.9.0" + } + }, + "node_modules/@babel/helper-simple-access": { + "version": "7.24.7", + "resolved": "https://registry.npmjs.org/@babel/helper-simple-access/-/helper-simple-access-7.24.7.tgz", + "integrity": "sha512-zBAIvbCMh5Ts+b86r/CjU+4XGYIs+R1j951gxI3KmmxBMhCg4oQMsv6ZXQ64XOm/cvzfU1FmoCyt6+owc5QMYg==", + "dev": true, + "dependencies": { + "@babel/traverse": "^7.24.7", + "@babel/types": "^7.24.7" + }, + "engines": { + "node": ">=6.9.0" + } + }, + "node_modules/@babel/helper-string-parser": { + "version": "7.24.8", + "resolved": "https://registry.npmjs.org/@babel/helper-string-parser/-/helper-string-parser-7.24.8.tgz", + "integrity": "sha512-pO9KhhRcuUyGnJWwyEgnRJTSIZHiT+vMD0kPeD+so0l7mxkMT19g3pjY9GTnHySck/hDzq+dtW/4VgnMkippsQ==", + "dev": true, + "engines": { + "node": ">=6.9.0" + } + }, + "node_modules/@babel/helper-validator-identifier": { + "version": "7.24.7", + "resolved": "https://registry.npmjs.org/@babel/helper-validator-identifier/-/helper-validator-identifier-7.24.7.tgz", + "integrity": "sha512-rR+PBcQ1SMQDDyF6X0wxtG8QyLCgUB0eRAGguqRLfkCA87l7yAP7ehq8SNj96OOGTO8OBV70KhuFYcIkHXOg0w==", + "dev": true, + "engines": { + "node": ">=6.9.0" + } + }, + "node_modules/@babel/helper-validator-option": { + "version": "7.24.8", + "resolved": "https://registry.npmjs.org/@babel/helper-validator-option/-/helper-validator-option-7.24.8.tgz", + "integrity": "sha512-xb8t9tD1MHLungh/AIoWYN+gVHaB9kwlu8gffXGSt3FFEIT7RjS+xWbc2vUD1UTZdIpKj/ab3rdqJ7ufngyi2Q==", + "dev": true, + "engines": { + "node": ">=6.9.0" + } + }, + "node_modules/@babel/helpers": { + "version": "7.25.6", + "resolved": "https://registry.npmjs.org/@babel/helpers/-/helpers-7.25.6.tgz", + "integrity": "sha512-Xg0tn4HcfTijTwfDwYlvVCl43V6h4KyVVX2aEm4qdO/PC6L2YvzLHFdmxhoeSA3eslcE6+ZVXHgWwopXYLNq4Q==", + "dev": true, + "dependencies": { + "@babel/template": "^7.25.0", + "@babel/types": "^7.25.6" + }, + "engines": { + "node": ">=6.9.0" + } + }, + "node_modules/@babel/highlight": { + "version": "7.24.7", + "resolved": "https://registry.npmjs.org/@babel/highlight/-/highlight-7.24.7.tgz", + "integrity": "sha512-EStJpq4OuY8xYfhGVXngigBJRWxftKX9ksiGDnmlY3o7B/V7KIAc9X4oiK87uPJSc/vs5L869bem5fhZa8caZw==", + "dev": true, + "dependencies": { + "@babel/helper-validator-identifier": "^7.24.7", + "chalk": "^2.4.2", + "js-tokens": "^4.0.0", + "picocolors": "^1.0.0" + }, + "engines": { + "node": ">=6.9.0" + } + }, + "node_modules/@babel/parser": { + "version": "7.25.6", + "resolved": "https://registry.npmjs.org/@babel/parser/-/parser-7.25.6.tgz", + "integrity": "sha512-trGdfBdbD0l1ZPmcJ83eNxB9rbEax4ALFTF7fN386TMYbeCQbyme5cOEXQhbGXKebwGaB/J52w1mrklMcbgy6Q==", + "dev": true, + "dependencies": { + "@babel/types": "^7.25.6" + }, + "bin": { + "parser": "bin/babel-parser.js" + }, + "engines": { + "node": ">=6.0.0" + } + }, + "node_modules/@babel/runtime": { + "version": "7.25.6", + "resolved": "https://registry.npmjs.org/@babel/runtime/-/runtime-7.25.6.tgz", + "integrity": "sha512-VBj9MYyDb9tuLq7yzqjgzt6Q+IBQLrGZfdjOekyEirZPHxXWoTSGUTMrpsfi58Up73d13NfYLv8HT9vmznjzhQ==", + "dependencies": { + "regenerator-runtime": "^0.14.0" + }, + "engines": { + "node": ">=6.9.0" + } + }, + "node_modules/@babel/template": { + "version": "7.25.0", + "resolved": "https://registry.npmjs.org/@babel/template/-/template-7.25.0.tgz", + "integrity": "sha512-aOOgh1/5XzKvg1jvVz7AVrx2piJ2XBi227DHmbY6y+bM9H2FlN+IfecYu4Xl0cNiiVejlsCri89LUsbj8vJD9Q==", + "dev": true, + "dependencies": { + "@babel/code-frame": "^7.24.7", + "@babel/parser": "^7.25.0", + "@babel/types": "^7.25.0" + }, + "engines": { + "node": ">=6.9.0" + } + }, + "node_modules/@babel/traverse": { + "version": "7.25.6", + "resolved": "https://registry.npmjs.org/@babel/traverse/-/traverse-7.25.6.tgz", + "integrity": "sha512-9Vrcx5ZW6UwK5tvqsj0nGpp/XzqthkT0dqIc9g1AdtygFToNtTF67XzYS//dm+SAK9cp3B9R4ZO/46p63SCjlQ==", + "dev": true, + "dependencies": { + "@babel/code-frame": "^7.24.7", + "@babel/generator": "^7.25.6", + "@babel/parser": "^7.25.6", + "@babel/template": "^7.25.0", + "@babel/types": "^7.25.6", + "debug": "^4.3.1", + "globals": "^11.1.0" + }, + "engines": { + "node": ">=6.9.0" + } + }, + "node_modules/@babel/types": { + "version": "7.25.6", + "resolved": "https://registry.npmjs.org/@babel/types/-/types-7.25.6.tgz", + "integrity": "sha512-/l42B1qxpG6RdfYf343Uw1vmDjeNhneUXtzhojE7pDgfpEypmRhI6j1kr17XCVv4Cgl9HdAiQY2x0GwKm7rWCw==", + "dev": true, + "dependencies": { + "@babel/helper-string-parser": "^7.24.8", + "@babel/helper-validator-identifier": "^7.24.7", + "to-fast-properties": "^2.0.0" + }, + "engines": { + "node": ">=6.9.0" + } + }, + "node_modules/@eslint-community/eslint-utils": { + "version": "4.4.0", + "resolved": "https://registry.npmjs.org/@eslint-community/eslint-utils/-/eslint-utils-4.4.0.tgz", + "integrity": "sha512-1/sA4dwrzBAyeUoQ6oxahHKmrZvsnLCg4RfxW3ZFGGmQkSNQPFNLV9CUEFQP1x9EYXHTo5p6xdhZM1Ne9p/AfA==", + "dev": true, + "dependencies": { + "eslint-visitor-keys": "^3.3.0" + }, + "engines": { + "node": "^12.22.0 || ^14.17.0 || >=16.0.0" + }, + "peerDependencies": { + "eslint": "^6.0.0 || ^7.0.0 || >=8.0.0" + } + }, + "node_modules/@eslint-community/regexpp": { + "version": "4.11.0", + "resolved": "https://registry.npmjs.org/@eslint-community/regexpp/-/regexpp-4.11.0.tgz", + "integrity": "sha512-G/M/tIiMrTAxEWRfLfQJMmGNX28IxBg4PBz8XqQhqUHLFI6TL2htpIB1iQCj144V5ee/JaKyT9/WZ0MGZWfA7A==", + "dev": true, + "engines": { + "node": "^12.0.0 || ^14.0.0 || >=16.0.0" + } + }, + "node_modules/@eslint/eslintrc": { + "version": "2.1.4", + "resolved": "https://registry.npmjs.org/@eslint/eslintrc/-/eslintrc-2.1.4.tgz", + "integrity": "sha512-269Z39MS6wVJtsoUl10L60WdkhJVdPG24Q4eZTH3nnF6lpvSShEK3wQjDX9JRWAUPvPh7COouPpU9IrqaZFvtQ==", + "dev": true, + "dependencies": { + "ajv": "^6.12.4", + "debug": "^4.3.2", + "espree": "^9.6.0", + "globals": "^13.19.0", + "ignore": "^5.2.0", + "import-fresh": "^3.2.1", + "js-yaml": "^4.1.0", + "minimatch": "^3.1.2", + "strip-json-comments": "^3.1.1" + }, + "engines": { + "node": "^12.22.0 || ^14.17.0 || >=16.0.0" + }, + "funding": { + "url": "https://opencollective.com/eslint" + } + }, + "node_modules/@eslint/eslintrc/node_modules/argparse": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/argparse/-/argparse-2.0.1.tgz", + "integrity": "sha512-8+9WqebbFzpX9OR+Wa6O29asIogeRMzcGtAINdpMHHyAg10f05aSFVBbcEqGf/PXw1EjAZ+q2/bEBg3DvurK3Q==", + "dev": true + }, + "node_modules/@eslint/eslintrc/node_modules/globals": { + "version": "13.24.0", + "resolved": "https://registry.npmjs.org/globals/-/globals-13.24.0.tgz", + "integrity": "sha512-AhO5QUcj8llrbG09iWhPU2B204J1xnPeL8kQmVorSsy+Sjj1sk8gIyh6cUocGmH4L0UuhAJy+hJMRA4mgA4mFQ==", + "dev": true, + "dependencies": { + "type-fest": "^0.20.2" + }, + "engines": { + "node": ">=8" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/@eslint/eslintrc/node_modules/js-yaml": { + "version": "4.1.0", + "resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-4.1.0.tgz", + "integrity": "sha512-wpxZs9NoxZaJESJGIZTyDEaYpl0FKSA+FB9aJiyemKhMwkxQg63h4T1KJgUGHpTqPDNRcmmYLugrRjJlBtWvRA==", + "dev": true, + "dependencies": { + "argparse": "^2.0.1" + }, + "bin": { + "js-yaml": "bin/js-yaml.js" + } + }, + "node_modules/@eslint/eslintrc/node_modules/type-fest": { + "version": "0.20.2", + "resolved": "https://registry.npmjs.org/type-fest/-/type-fest-0.20.2.tgz", + "integrity": "sha512-Ne+eE4r0/iWnpAxD852z3A+N0Bt5RN//NjJwRd2VFHEmrywxf5vsZlh4R6lixl6B+wz/8d+maTSAkN1FIkI3LQ==", + "dev": true, + "engines": { + "node": ">=10" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/@eslint/js": { + "version": "8.57.0", + "resolved": "https://registry.npmjs.org/@eslint/js/-/js-8.57.0.tgz", + "integrity": "sha512-Ys+3g2TaW7gADOJzPt83SJtCDhMjndcDMFVQ/Tj9iA1BfJzFKD9mAUXT3OenpuPHbI6P/myECxRJrofUsDx/5g==", + "dev": true, + "engines": { + "node": "^12.22.0 || ^14.17.0 || >=16.0.0" + } + }, + "node_modules/@humanwhocodes/config-array": { + "version": "0.11.14", + "resolved": "https://registry.npmjs.org/@humanwhocodes/config-array/-/config-array-0.11.14.tgz", + "integrity": "sha512-3T8LkOmg45BV5FICb15QQMsyUSWrQ8AygVfC7ZG32zOalnqrilm018ZVCw0eapXux8FtA33q8PSRSstjee3jSg==", + "deprecated": "Use @eslint/config-array instead", + "dev": true, + "dependencies": { + "@humanwhocodes/object-schema": "^2.0.2", + "debug": "^4.3.1", + "minimatch": "^3.0.5" + }, + "engines": { + "node": ">=10.10.0" + } + }, + "node_modules/@humanwhocodes/module-importer": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/@humanwhocodes/module-importer/-/module-importer-1.0.1.tgz", + "integrity": "sha512-bxveV4V8v5Yb4ncFTT3rPSgZBOpCkjfK0y4oVVVJwIuDVBRMDXrPyXRL988i5ap9m9bnyEEjWfm5WkBmtffLfA==", + "dev": true, + "engines": { + "node": ">=12.22" + }, + "funding": { + "type": "github", + "url": "https://github.com/sponsors/nzakas" + } + }, + "node_modules/@humanwhocodes/object-schema": { + "version": "2.0.3", + "resolved": "https://registry.npmjs.org/@humanwhocodes/object-schema/-/object-schema-2.0.3.tgz", + "integrity": "sha512-93zYdMES/c1D69yZiKDBj0V24vqNzB/koF26KPaagAfd3P/4gUlh3Dys5ogAK+Exi9QyzlD8x/08Zt7wIKcDcA==", + "deprecated": "Use @eslint/object-schema instead", + "dev": true + }, + "node_modules/@istanbuljs/load-nyc-config": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/@istanbuljs/load-nyc-config/-/load-nyc-config-1.1.0.tgz", + "integrity": "sha512-VjeHSlIzpv/NyD3N0YuHfXOPDIixcA1q2ZV98wsMqcYlPmv2n3Yb2lYP9XMElnaFVXg5A7YLTeLu6V84uQDjmQ==", + "dev": true, + "dependencies": { + "camelcase": "^5.3.1", + "find-up": "^4.1.0", + "get-package-type": "^0.1.0", + "js-yaml": "^3.13.1", + "resolve-from": "^5.0.0" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/@istanbuljs/schema": { + "version": "0.1.3", + "resolved": "https://registry.npmjs.org/@istanbuljs/schema/-/schema-0.1.3.tgz", + "integrity": "sha512-ZXRY4jNvVgSVQ8DL3LTcakaAtXwTVUxE81hslsyD2AtoXW/wVob10HkOJ1X/pAlcI7D+2YoZKg5do8G/w6RYgA==", + "dev": true, + "engines": { + "node": ">=8" + } + }, + "node_modules/@jridgewell/gen-mapping": { + "version": "0.3.5", + "resolved": "https://registry.npmjs.org/@jridgewell/gen-mapping/-/gen-mapping-0.3.5.tgz", + "integrity": "sha512-IzL8ZoEDIBRWEzlCcRhOaCupYyN5gdIK+Q6fbFdPDg6HqX6jpkItn7DFIpW9LQzXG6Df9sA7+OKnq0qlz/GaQg==", + "dev": true, + "dependencies": { + "@jridgewell/set-array": "^1.2.1", + "@jridgewell/sourcemap-codec": "^1.4.10", + "@jridgewell/trace-mapping": "^0.3.24" + }, + "engines": { + "node": ">=6.0.0" + } + }, + "node_modules/@jridgewell/resolve-uri": { + "version": "3.1.2", + "resolved": "https://registry.npmjs.org/@jridgewell/resolve-uri/-/resolve-uri-3.1.2.tgz", + "integrity": "sha512-bRISgCIjP20/tbWSPWMEi54QVPRZExkuD9lJL+UIxUKtwVJA8wW1Trb1jMs1RFXo1CBTNZ/5hpC9QvmKWdopKw==", + "dev": true, + "engines": { + "node": ">=6.0.0" + } + }, + "node_modules/@jridgewell/set-array": { + "version": "1.2.1", + "resolved": "https://registry.npmjs.org/@jridgewell/set-array/-/set-array-1.2.1.tgz", + "integrity": "sha512-R8gLRTZeyp03ymzP/6Lil/28tGeGEzhx1q2k703KGWRAI1VdvPIXdG70VJc2pAMw3NA6JKL5hhFu1sJX0Mnn/A==", + "dev": true, + "engines": { + "node": ">=6.0.0" + } + }, + "node_modules/@jridgewell/sourcemap-codec": { + "version": "1.5.0", + "resolved": "https://registry.npmjs.org/@jridgewell/sourcemap-codec/-/sourcemap-codec-1.5.0.tgz", + "integrity": "sha512-gv3ZRaISU3fjPAgNsriBRqGWQL6quFx04YMPW/zD8XMLsU32mhCCbfbO6KZFLjvYpCZ8zyDEgqsgf+PwPaM7GQ==", + "dev": true + }, + "node_modules/@jridgewell/trace-mapping": { + "version": "0.3.25", + "resolved": "https://registry.npmjs.org/@jridgewell/trace-mapping/-/trace-mapping-0.3.25.tgz", + "integrity": "sha512-vNk6aEwybGtawWmy/PzwnGDOjCkLWSD2wqvjGGAgOAwCGWySYXfYoxt00IJkTF+8Lb57DwOb3Aa0o9CApepiYQ==", + "dev": true, + "dependencies": { + "@jridgewell/resolve-uri": "^3.1.0", + "@jridgewell/sourcemap-codec": "^1.4.14" + } + }, + "node_modules/@nodelib/fs.scandir": { + "version": "2.1.5", + "resolved": "https://registry.npmjs.org/@nodelib/fs.scandir/-/fs.scandir-2.1.5.tgz", + "integrity": "sha512-vq24Bq3ym5HEQm2NKCr3yXDwjc7vTsEThRDnkp2DK9p1uqLR+DHurm/NOTo0KG7HYHU7eppKZj3MyqYuMBf62g==", + "dev": true, + "dependencies": { + "@nodelib/fs.stat": "2.0.5", + "run-parallel": "^1.1.9" + }, + "engines": { + "node": ">= 8" + } + }, + "node_modules/@nodelib/fs.stat": { + "version": "2.0.5", + "resolved": "https://registry.npmjs.org/@nodelib/fs.stat/-/fs.stat-2.0.5.tgz", + "integrity": "sha512-RkhPPp2zrqDAQA/2jNhnztcPAlv64XdhIp7a7454A5ovI7Bukxgt7MX7udwAu3zg1DcpPU0rz3VV1SeaqvY4+A==", + "dev": true, + "engines": { + "node": ">= 8" + } + }, + "node_modules/@nodelib/fs.walk": { + "version": "1.2.8", + "resolved": "https://registry.npmjs.org/@nodelib/fs.walk/-/fs.walk-1.2.8.tgz", + "integrity": "sha512-oGB+UxlgWcgQkgwo8GcEGwemoTFt3FIO9ababBmaGwXIoBKZ+GTy0pP185beGg7Llih/NSHSV2XAs1lnznocSg==", + "dev": true, + "dependencies": { + "@nodelib/fs.scandir": "2.1.5", + "fastq": "^1.6.0" + }, + "engines": { + "node": ">= 8" + } + }, + "node_modules/@puppeteer/browsers": { + "version": "0.5.0", + "resolved": "https://registry.npmjs.org/@puppeteer/browsers/-/browsers-0.5.0.tgz", + "integrity": "sha512-Uw6oB7VvmPRLE4iKsjuOh8zgDabhNX67dzo8U/BB0f9527qx+4eeUs+korU98OhG5C4ubg7ufBgVi63XYwS6TQ==", + "dev": true, + "dependencies": { + "debug": "4.3.4", + "extract-zip": "2.0.1", + "https-proxy-agent": "5.0.1", + "progress": "2.0.3", + "proxy-from-env": "1.1.0", + "tar-fs": "2.1.1", + "unbzip2-stream": "1.4.3", + "yargs": "17.7.1" + }, + "bin": { + "browsers": "lib/cjs/main-cli.js" + }, + "engines": { + "node": ">=14.1.0" + }, + "peerDependencies": { + "typescript": ">= 4.7.4" + }, + "peerDependenciesMeta": { + "typescript": { + "optional": true + } + } + }, + "node_modules/@puppeteer/browsers/node_modules/ansi-styles": { + "version": "4.3.0", + "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", + "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", + "dev": true, + "dependencies": { + "color-convert": "^2.0.1" + }, + "engines": { + "node": ">=8" + }, + "funding": { + "url": "https://github.com/chalk/ansi-styles?sponsor=1" + } + }, + "node_modules/@puppeteer/browsers/node_modules/cliui": { + "version": "8.0.1", + "resolved": "https://registry.npmjs.org/cliui/-/cliui-8.0.1.tgz", + "integrity": "sha512-BSeNnyus75C4//NQ9gQt1/csTXyo/8Sb+afLAkzAptFuMsod9HFokGNudZpi/oQV73hnVK+sR+5PVRMd+Dr7YQ==", + "dev": true, + "dependencies": { + "string-width": "^4.2.0", + "strip-ansi": "^6.0.1", + "wrap-ansi": "^7.0.0" + }, + "engines": { + "node": ">=12" + } + }, + "node_modules/@puppeteer/browsers/node_modules/color-convert": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", + "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", + "dev": true, + "dependencies": { + "color-name": "~1.1.4" + }, + "engines": { + "node": ">=7.0.0" + } + }, + "node_modules/@puppeteer/browsers/node_modules/color-name": { + "version": "1.1.4", + "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", + "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", + "dev": true + }, + "node_modules/@puppeteer/browsers/node_modules/debug": { + "version": "4.3.4", + "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.4.tgz", + "integrity": "sha512-PRWFHuSU3eDtQJPvnNY7Jcket1j0t5OuOsFzPPzsekD52Zl8qUfFIPEiswXqIvHWGVHOgX+7G/vCNNhehwxfkQ==", + "dev": true, + "dependencies": { + "ms": "2.1.2" + }, + "engines": { + "node": ">=6.0" + }, + "peerDependenciesMeta": { + "supports-color": { + "optional": true + } + } + }, + "node_modules/@puppeteer/browsers/node_modules/wrap-ansi": { + "version": "7.0.0", + "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-7.0.0.tgz", + "integrity": "sha512-YVGIj2kamLSTxw6NsZjoBxfSwsn0ycdesmc4p+Q21c5zPuZ1pl+NfxVdxPtdHvmNVOQ6XSYG4AUtyt/Fi7D16Q==", + "dev": true, + "dependencies": { + "ansi-styles": "^4.0.0", + "string-width": "^4.1.0", + "strip-ansi": "^6.0.0" + }, + "engines": { + "node": ">=10" + }, + "funding": { + "url": "https://github.com/chalk/wrap-ansi?sponsor=1" + } + }, + "node_modules/@puppeteer/browsers/node_modules/y18n": { + "version": "5.0.8", + "resolved": "https://registry.npmjs.org/y18n/-/y18n-5.0.8.tgz", + "integrity": "sha512-0pfFzegeDWJHJIAmTLRP2DwHjdF5s7jo9tuztdQxAhINCdvS+3nGINqPd00AphqJR/0LhANUS6/+7SCb98YOfA==", + "dev": true, + "engines": { + "node": ">=10" + } + }, + "node_modules/@puppeteer/browsers/node_modules/yargs": { + "version": "17.7.1", + "resolved": "https://registry.npmjs.org/yargs/-/yargs-17.7.1.tgz", + "integrity": "sha512-cwiTb08Xuv5fqF4AovYacTFNxk62th7LKJ6BL9IGUpTJrWoU7/7WdQGTP2SjKf1dUNBGzDd28p/Yfs/GI6JrLw==", + "dev": true, + "dependencies": { + "cliui": "^8.0.1", + "escalade": "^3.1.1", + "get-caller-file": "^2.0.5", + "require-directory": "^2.1.1", + "string-width": "^4.2.3", + "y18n": "^5.0.5", + "yargs-parser": "^21.1.1" + }, + "engines": { + "node": ">=12" + } + }, + "node_modules/@puppeteer/browsers/node_modules/yargs-parser": { + "version": "21.1.1", + "resolved": "https://registry.npmjs.org/yargs-parser/-/yargs-parser-21.1.1.tgz", + "integrity": "sha512-tVpsJW7DdjecAiFpbIB1e3qxIQsE6NoPc5/eTdrbbIC4h0LVsWhnoa3g+m2HclBIujHzsxZ4VJVA+GUuc2/LBw==", + "dev": true, + "engines": { + "node": ">=12" + } + }, + "node_modules/@types/json5": { + "version": "0.0.29", + "resolved": "https://registry.npmjs.org/@types/json5/-/json5-0.0.29.tgz", + "integrity": "sha512-dRLjCWHYg4oaA77cxO64oO+7JwCwnIzkZPdrrC71jQmQtlhM556pwKo5bUzqvZndkVbeFLIIi+9TC40JNF5hNQ==", + "dev": true + }, + "node_modules/@types/node": { + "version": "22.5.1", + "resolved": "https://registry.npmjs.org/@types/node/-/node-22.5.1.tgz", + "integrity": "sha512-KkHsxej0j9IW1KKOOAA/XBA0z08UFSrRQHErzEfA3Vgq57eXIMYboIlHJuYIfd+lwCQjtKqUu3UnmKbtUc9yRw==", + "dev": true, + "optional": true, + "dependencies": { + "undici-types": "~6.19.2" + } + }, + "node_modules/@types/yauzl": { + "version": "2.10.3", + "resolved": "https://registry.npmjs.org/@types/yauzl/-/yauzl-2.10.3.tgz", + "integrity": "sha512-oJoftv0LSuaDZE3Le4DbKX+KS9G36NzOeSap90UIK0yMA/NhKJhqlSGtNDORNRaIbQfzjXDrQa0ytJ6mNRGz/Q==", + "dev": true, + "optional": true, + "dependencies": { + "@types/node": "*" + } + }, + "node_modules/@ungap/structured-clone": { + "version": "1.2.0", + "resolved": "https://registry.npmjs.org/@ungap/structured-clone/-/structured-clone-1.2.0.tgz", + "integrity": "sha512-zuVdFrMJiuCDQUMCzQaD6KL28MjnqqN8XnAqiEq9PNm/hCPTSGfrXCOfwj1ow4LFb/tNymJPwsNbVePc1xFqrQ==", + "dev": true + }, + "node_modules/acorn": { + "version": "8.12.1", + "resolved": "https://registry.npmjs.org/acorn/-/acorn-8.12.1.tgz", + "integrity": "sha512-tcpGyI9zbizT9JbV6oYE477V6mTlXvvi0T0G3SNIYE2apm/G5huBa1+K89VGeovbg+jycCrfhl3ADxErOuO6Jg==", + "dev": true, + "bin": { + "acorn": "bin/acorn" + }, + "engines": { + "node": ">=0.4.0" + } + }, + "node_modules/acorn-jsx": { + "version": "5.3.2", + "resolved": "https://registry.npmjs.org/acorn-jsx/-/acorn-jsx-5.3.2.tgz", + "integrity": "sha512-rq9s+JNhf0IChjtDXxllJ7g41oZk5SlXtp0LHwyA5cejwn7vKmKp4pPri6YEePv2PU65sAsegbXtIinmDFDXgQ==", + "dev": true, + "peerDependencies": { + "acorn": "^6.0.0 || ^7.0.0 || ^8.0.0" + } + }, + "node_modules/agent-base": { + "version": "6.0.2", + "resolved": "https://registry.npmjs.org/agent-base/-/agent-base-6.0.2.tgz", + "integrity": "sha512-RZNwNclF7+MS/8bDg70amg32dyeZGZxiDuQmZxKLAlQjr3jGyLx+4Kkk58UO7D2QdgFIQCovuSuZESne6RG6XQ==", + "dev": true, + "dependencies": { + "debug": "4" + }, + "engines": { + "node": ">= 6.0.0" + } + }, + "node_modules/aggregate-error": { + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/aggregate-error/-/aggregate-error-3.1.0.tgz", + "integrity": "sha512-4I7Td01quW/RpocfNayFdFVk1qSuoh0E7JrbRJ16nH01HhKFQ88INq9Sd+nd72zqRySlr9BmDA8xlEJ6vJMrYA==", + "dev": true, + "dependencies": { + "clean-stack": "^2.0.0", + "indent-string": "^4.0.0" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/ajv": { + "version": "6.12.6", + "resolved": "https://registry.npmjs.org/ajv/-/ajv-6.12.6.tgz", + "integrity": "sha512-j3fVLgvTo527anyYyJOGTYJbG+vnnQYvE0m5mmkc1TK+nxAppkCLMIL0aZ4dblVCNoGShhm+kzE4ZUykBoMg4g==", + "dev": true, + "dependencies": { + "fast-deep-equal": "^3.1.1", + "fast-json-stable-stringify": "^2.0.0", + "json-schema-traverse": "^0.4.1", + "uri-js": "^4.2.2" + }, + "funding": { + "type": "github", + "url": "https://github.com/sponsors/epoberezkin" + } + }, + "node_modules/ansi-regex": { + "version": "5.0.1", + "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.1.tgz", + "integrity": "sha512-quJQXlTSUGL2LH9SUXo8VwsY4soanhgo6LNSm84E1LBcE8s3O0wpdiRzyR9z/ZZJMlMWv37qOOb9pdJlMUEKFQ==", + "dev": true, + "engines": { + "node": ">=8" + } + }, + "node_modules/ansi-styles": { + "version": "3.2.1", + "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-3.2.1.tgz", + "integrity": "sha512-VT0ZI6kZRdTh8YyJw3SMbYm/u+NqfsAxEpWO0Pf9sq8/e94WxxOpPKx9FR1FlyCtOVDNOQ+8ntlqFxiRc+r5qA==", + "dev": true, + "dependencies": { + "color-convert": "^1.9.0" + }, + "engines": { + "node": ">=4" + } + }, + "node_modules/append-transform": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/append-transform/-/append-transform-2.0.0.tgz", + "integrity": "sha512-7yeyCEurROLQJFv5Xj4lEGTy0borxepjFv1g22oAdqFu//SrAlDl1O1Nxx15SH1RoliUml6p8dwJW9jvZughhg==", + "dev": true, + "dependencies": { + "default-require-extensions": "^3.0.0" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/archy": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/archy/-/archy-1.0.0.tgz", + "integrity": "sha512-Xg+9RwCg/0p32teKdGMPTPnVXKD0w3DfHnFTficozsAgsvq2XenPJq/MYpzzQ/v8zrOyJn6Ds39VA4JIDwFfqw==", + "dev": true + }, + "node_modules/argparse": { + "version": "1.0.10", + "resolved": "https://registry.npmjs.org/argparse/-/argparse-1.0.10.tgz", + "integrity": "sha512-o5Roy6tNG4SL/FOkCAN6RzjiakZS25RLYFrcMttJqbdd8BWrnA+fGz57iN5Pb06pvBGvl5gQ0B48dJlslXvoTg==", + "dev": true, + "dependencies": { + "sprintf-js": "~1.0.2" + } + }, + "node_modules/array-buffer-byte-length": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/array-buffer-byte-length/-/array-buffer-byte-length-1.0.1.tgz", + "integrity": "sha512-ahC5W1xgou+KTXix4sAO8Ki12Q+jf4i0+tmk3sC+zgcynshkHxzpXdImBehiUYKKKDwvfFiJl1tZt6ewscS1Mg==", + "dev": true, + "dependencies": { + "call-bind": "^1.0.5", + "is-array-buffer": "^3.0.4" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/array-includes": { + "version": "3.1.8", + "resolved": "https://registry.npmjs.org/array-includes/-/array-includes-3.1.8.tgz", + "integrity": "sha512-itaWrbYbqpGXkGhZPGUulwnhVf5Hpy1xiCFsGqyIGglbBxmG5vSjxQen3/WGOjPpNEv1RtBLKxbmVXm8HpJStQ==", + "dev": true, + "dependencies": { + "call-bind": "^1.0.7", + "define-properties": "^1.2.1", + "es-abstract": "^1.23.2", + "es-object-atoms": "^1.0.0", + "get-intrinsic": "^1.2.4", + "is-string": "^1.0.7" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/array.prototype.findlast": { + "version": "1.2.5", + "resolved": "https://registry.npmjs.org/array.prototype.findlast/-/array.prototype.findlast-1.2.5.tgz", + "integrity": "sha512-CVvd6FHg1Z3POpBLxO6E6zr+rSKEQ9L6rZHAaY7lLfhKsWYUBBOuMs0e9o24oopj6H+geRCX0YJ+TJLBK2eHyQ==", + "dev": true, + "dependencies": { + "call-bind": "^1.0.7", + "define-properties": "^1.2.1", + "es-abstract": "^1.23.2", + "es-errors": "^1.3.0", + "es-object-atoms": "^1.0.0", + "es-shim-unscopables": "^1.0.2" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/array.prototype.findlastindex": { + "version": "1.2.5", + "resolved": "https://registry.npmjs.org/array.prototype.findlastindex/-/array.prototype.findlastindex-1.2.5.tgz", + "integrity": "sha512-zfETvRFA8o7EiNn++N5f/kaCw221hrpGsDmcpndVupkPzEc1Wuf3VgC0qby1BbHs7f5DVYjgtEU2LLh5bqeGfQ==", + "dev": true, + "dependencies": { + "call-bind": "^1.0.7", + "define-properties": "^1.2.1", + "es-abstract": "^1.23.2", + "es-errors": "^1.3.0", + "es-object-atoms": "^1.0.0", + "es-shim-unscopables": "^1.0.2" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/array.prototype.flat": { + "version": "1.3.2", + "resolved": "https://registry.npmjs.org/array.prototype.flat/-/array.prototype.flat-1.3.2.tgz", + "integrity": "sha512-djYB+Zx2vLewY8RWlNCUdHjDXs2XOgm602S9E7P/UpHgfeHL00cRiIF+IN/G/aUJ7kGPb6yO/ErDI5V2s8iycA==", + "dev": true, + "dependencies": { + "call-bind": "^1.0.2", + "define-properties": "^1.2.0", + "es-abstract": "^1.22.1", + "es-shim-unscopables": "^1.0.0" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/array.prototype.flatmap": { + "version": "1.3.2", + "resolved": "https://registry.npmjs.org/array.prototype.flatmap/-/array.prototype.flatmap-1.3.2.tgz", + "integrity": "sha512-Ewyx0c9PmpcsByhSW4r+9zDU7sGjFc86qf/kKtuSCRdhfbk0SNLLkaT5qvcHnRGgc5NP/ly/y+qkXkqONX54CQ==", + "dev": true, + "dependencies": { + "call-bind": "^1.0.2", + "define-properties": "^1.2.0", + "es-abstract": "^1.22.1", + "es-shim-unscopables": "^1.0.0" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/array.prototype.tosorted": { + "version": "1.1.4", + "resolved": "https://registry.npmjs.org/array.prototype.tosorted/-/array.prototype.tosorted-1.1.4.tgz", + "integrity": "sha512-p6Fx8B7b7ZhL/gmUsAy0D15WhvDccw3mnGNbZpi3pmeJdxtWsj2jEaI4Y6oo3XiHfzuSgPwKc04MYt6KgvC/wA==", + "dev": true, + "dependencies": { + "call-bind": "^1.0.7", + "define-properties": "^1.2.1", + "es-abstract": "^1.23.3", + "es-errors": "^1.3.0", + "es-shim-unscopables": "^1.0.2" + }, + "engines": { + "node": ">= 0.4" + } + }, + "node_modules/arraybuffer.prototype.slice": { + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/arraybuffer.prototype.slice/-/arraybuffer.prototype.slice-1.0.3.tgz", + "integrity": "sha512-bMxMKAjg13EBSVscxTaYA4mRc5t1UAXa2kXiGTNfZ079HIWXEkKmkgFrh/nJqamaLSrXO5H4WFFkPEaLJWbs3A==", + "dev": true, + "dependencies": { + "array-buffer-byte-length": "^1.0.1", + "call-bind": "^1.0.5", + "define-properties": "^1.2.1", + "es-abstract": "^1.22.3", + "es-errors": "^1.2.1", + "get-intrinsic": "^1.2.3", + "is-array-buffer": "^3.0.4", + "is-shared-array-buffer": "^1.0.2" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/assertion-error": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/assertion-error/-/assertion-error-1.1.0.tgz", + "integrity": "sha512-jgsaNduz+ndvGyFt3uSuWqvy4lCnIJiovtouQN5JZHOKCS2QuhEdbcQHFhVksz2N2U9hXJo8odG7ETyWlEeuDw==", + "dev": true, + "engines": { + "node": "*" + } + }, + "node_modules/available-typed-arrays": { + "version": "1.0.7", + "resolved": "https://registry.npmjs.org/available-typed-arrays/-/available-typed-arrays-1.0.7.tgz", + "integrity": "sha512-wvUjBtSGN7+7SjNpq/9M2Tg350UZD3q62IFZLbRAR1bSMlCo1ZaeW+BJ+D090e4hIIZLBcTDWe4Mh4jvUDajzQ==", + "dev": true, + "dependencies": { + "possible-typed-array-names": "^1.0.0" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/babel-plugin-istanbul": { + "version": "6.1.1", + "resolved": "https://registry.npmjs.org/babel-plugin-istanbul/-/babel-plugin-istanbul-6.1.1.tgz", + "integrity": "sha512-Y1IQok9821cC9onCx5otgFfRm7Lm+I+wwxOx738M/WLPZ9Q42m4IG5W0FNX8WLL2gYMZo3JkuXIH2DOpWM+qwA==", + "dev": true, + "dependencies": { + "@babel/helper-plugin-utils": "^7.0.0", + "@istanbuljs/load-nyc-config": "^1.0.0", + "@istanbuljs/schema": "^0.1.2", + "istanbul-lib-instrument": "^5.0.4", + "test-exclude": "^6.0.0" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/balanced-match": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.2.tgz", + "integrity": "sha512-3oSeUO0TMV67hN1AmbXsK4yaqU7tjiHlbxRDZOpH0KW9+CeX4bRAaX0Anxt0tx2MrpRpWwQaPwIlISEJhYU5Pw==", + "dev": true + }, + "node_modules/base64-js": { + "version": "1.5.1", + "resolved": "https://registry.npmjs.org/base64-js/-/base64-js-1.5.1.tgz", + "integrity": "sha512-AKpaYlHn8t4SVbOHCy+b5+KKgvR4vrsD8vbvrbiQJps7fKDTkjkDry6ji0rUJjC0kzbNePLwzxq8iypo41qeWA==", + "dev": true, + "funding": [ + { + "type": "github", + "url": "https://github.com/sponsors/feross" + }, + { + "type": "patreon", + "url": "https://www.patreon.com/feross" + }, + { + "type": "consulting", + "url": "https://feross.org/support" + } + ] + }, + "node_modules/bl": { + "version": "4.1.0", + "resolved": "https://registry.npmjs.org/bl/-/bl-4.1.0.tgz", + "integrity": "sha512-1W07cM9gS6DcLperZfFSj+bWLtaPGSOHWhPiGzXmvVJbRLdG82sH/Kn8EtW1VqWVA54AKf2h5k5BbnIbwF3h6w==", + "dev": true, + "dependencies": { + "buffer": "^5.5.0", + "inherits": "^2.0.4", + "readable-stream": "^3.4.0" + } + }, + "node_modules/brace-expansion": { + "version": "1.1.11", + "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", + "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", + "dev": true, + "dependencies": { + "balanced-match": "^1.0.0", + "concat-map": "0.0.1" + } + }, + "node_modules/browserslist": { + "version": "4.23.3", + "resolved": "https://registry.npmjs.org/browserslist/-/browserslist-4.23.3.tgz", + "integrity": "sha512-btwCFJVjI4YWDNfau8RhZ+B1Q/VLoUITrm3RlP6y1tYGWIOa+InuYiRGXUBXo8nA1qKmHMyLB/iVQg5TT4eFoA==", + "dev": true, + "funding": [ + { + "type": "opencollective", + "url": "https://opencollective.com/browserslist" + }, + { + "type": "tidelift", + "url": "https://tidelift.com/funding/github/npm/browserslist" + }, + { + "type": "github", + "url": "https://github.com/sponsors/ai" + } + ], + "dependencies": { + "caniuse-lite": "^1.0.30001646", + "electron-to-chromium": "^1.5.4", + "node-releases": "^2.0.18", + "update-browserslist-db": "^1.1.0" + }, + "bin": { + "browserslist": "cli.js" + }, + "engines": { + "node": "^6 || ^7 || ^8 || ^9 || ^10 || ^11 || ^12 || >=13.7" + } + }, + "node_modules/buffer": { + "version": "5.7.1", + "resolved": "https://registry.npmjs.org/buffer/-/buffer-5.7.1.tgz", + "integrity": "sha512-EHcyIPBQ4BSGlvjB16k5KgAJ27CIsHY/2JBmCRReo48y9rQ3MaUzWX3KVlBa4U7MyX02HdVj0K7C3WaB3ju7FQ==", + "dev": true, + "funding": [ + { + "type": "github", + "url": "https://github.com/sponsors/feross" + }, + { + "type": "patreon", + "url": "https://www.patreon.com/feross" + }, + { + "type": "consulting", + "url": "https://feross.org/support" + } + ], + "dependencies": { + "base64-js": "^1.3.1", + "ieee754": "^1.1.13" + } + }, + "node_modules/buffer-crc32": { + "version": "0.2.13", + "resolved": "https://registry.npmjs.org/buffer-crc32/-/buffer-crc32-0.2.13.tgz", + "integrity": "sha512-VO9Ht/+p3SN7SKWqcrgEzjGbRSJYTx+Q1pTQC0wrWqHx0vpJraQ6GtHx8tvcg1rlK1byhU5gccxgOgj7B0TDkQ==", + "dev": true, + "engines": { + "node": "*" + } + }, + "node_modules/builtins": { + "version": "5.1.0", + "resolved": "https://registry.npmjs.org/builtins/-/builtins-5.1.0.tgz", + "integrity": "sha512-SW9lzGTLvWTP1AY8xeAMZimqDrIaSdLQUcVr9DMef51niJ022Ri87SwRRKYm4A6iHfkPaiVUu/Duw2Wc4J7kKg==", + "dev": true, + "dependencies": { + "semver": "^7.0.0" + } + }, + "node_modules/builtins/node_modules/semver": { + "version": "7.6.3", + "resolved": "https://registry.npmjs.org/semver/-/semver-7.6.3.tgz", + "integrity": "sha512-oVekP1cKtI+CTDvHWYFUcMtsK/00wmAEfyqKfNdARm8u1wNVhSgaX7A8d4UuIlUI5e84iEwOhs7ZPYRmzU9U6A==", + "dev": true, + "bin": { + "semver": "bin/semver.js" + }, + "engines": { + "node": ">=10" + } + }, + "node_modules/caching-transform": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/caching-transform/-/caching-transform-4.0.0.tgz", + "integrity": "sha512-kpqOvwXnjjN44D89K5ccQC+RUrsy7jB/XLlRrx0D7/2HNcTPqzsb6XgYoErwko6QsV184CA2YgS1fxDiiDZMWA==", + "dev": true, + "dependencies": { + "hasha": "^5.0.0", + "make-dir": "^3.0.0", + "package-hash": "^4.0.0", + "write-file-atomic": "^3.0.0" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/call-bind": { + "version": "1.0.7", + "resolved": "https://registry.npmjs.org/call-bind/-/call-bind-1.0.7.tgz", + "integrity": "sha512-GHTSNSYICQ7scH7sZ+M2rFopRoLh8t2bLSW6BbgrtLsahOIB5iyAVJf9GjWK3cYTDaMj4XdBpM1cA6pIS0Kv2w==", + "dev": true, + "dependencies": { + "es-define-property": "^1.0.0", + "es-errors": "^1.3.0", + "function-bind": "^1.1.2", + "get-intrinsic": "^1.2.4", + "set-function-length": "^1.2.1" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/callsites": { + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/callsites/-/callsites-3.1.0.tgz", + "integrity": "sha512-P8BjAsXvZS+VIDUI11hHCQEv74YT67YUi5JJFNWIqL235sBmjX4+qx9Muvls5ivyNENctx46xQLQ3aTuE7ssaQ==", + "dev": true, + "engines": { + "node": ">=6" + } + }, + "node_modules/camelcase": { + "version": "5.3.1", + "resolved": "https://registry.npmjs.org/camelcase/-/camelcase-5.3.1.tgz", + "integrity": "sha512-L28STB170nwWS63UjtlEOE3dldQApaJXZkOI1uMFfzf3rRuPegHaHesyee+YxQ+W6SvRDQV6UrdOdRiR153wJg==", + "dev": true, + "engines": { + "node": ">=6" + } + }, + "node_modules/caniuse-lite": { + "version": "1.0.30001655", + "resolved": "https://registry.npmjs.org/caniuse-lite/-/caniuse-lite-1.0.30001655.tgz", + "integrity": "sha512-jRGVy3iSGO5Uutn2owlb5gR6qsGngTw9ZTb4ali9f3glshcNmJ2noam4Mo9zia5P9Dk3jNNydy7vQjuE5dQmfg==", + "dev": true, + "funding": [ + { + "type": "opencollective", + "url": "https://opencollective.com/browserslist" + }, + { + "type": "tidelift", + "url": "https://tidelift.com/funding/github/npm/caniuse-lite" + }, + { + "type": "github", + "url": "https://github.com/sponsors/ai" + } + ] + }, + "node_modules/chai": { + "version": "4.5.0", + "resolved": "https://registry.npmjs.org/chai/-/chai-4.5.0.tgz", + "integrity": "sha512-RITGBfijLkBddZvnn8jdqoTypxvqbOLYQkGGxXzeFjVHvudaPw0HNFD9x928/eUwYWd2dPCugVqspGALTZZQKw==", + "dev": true, + "dependencies": { + "assertion-error": "^1.1.0", + "check-error": "^1.0.3", + "deep-eql": "^4.1.3", + "get-func-name": "^2.0.2", + "loupe": "^2.3.6", + "pathval": "^1.1.1", + "type-detect": "^4.1.0" + }, + "engines": { + "node": ">=4" + } + }, + "node_modules/chai-as-promised": { + "version": "7.1.2", + "resolved": "https://registry.npmjs.org/chai-as-promised/-/chai-as-promised-7.1.2.tgz", + "integrity": "sha512-aBDHZxRzYnUYuIAIPBH2s511DjlKPzXNlXSGFC8CwmroWQLfrW0LtE1nK3MAwwNhJPa9raEjNCmRoFpG0Hurdw==", + "dev": true, + "dependencies": { + "check-error": "^1.0.2" + }, + "peerDependencies": { + "chai": ">= 2.1.2 < 6" + } + }, + "node_modules/chalk": { + "version": "2.4.2", + "resolved": "https://registry.npmjs.org/chalk/-/chalk-2.4.2.tgz", + "integrity": "sha512-Mti+f9lpJNcwF4tWV8/OrTTtF1gZi+f8FqlyAdouralcFWFQWF2+NgCHShjkCb+IFBLq9buZwE1xckQU4peSuQ==", + "dev": true, + "dependencies": { + "ansi-styles": "^3.2.1", + "escape-string-regexp": "^1.0.5", + "supports-color": "^5.3.0" + }, + "engines": { + "node": ">=4" + } + }, + "node_modules/check-error": { + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/check-error/-/check-error-1.0.3.tgz", + "integrity": "sha512-iKEoDYaRmd1mxM90a2OEfWhjsjPpYPuQ+lMYsoxB126+t8fw7ySEO48nmDg5COTjxDI65/Y2OWpeEHk3ZOe8zg==", + "dev": true, + "dependencies": { + "get-func-name": "^2.0.2" + }, + "engines": { + "node": "*" + } + }, + "node_modules/chownr": { + "version": "1.1.4", + "resolved": "https://registry.npmjs.org/chownr/-/chownr-1.1.4.tgz", + "integrity": "sha512-jJ0bqzaylmJtVnNgzTeSOs8DPavpbYgEr/b0YL8/2GO3xJEhInFmhKMUnEJQjZumK7KXGFhUy89PrsJWlakBVg==", + "dev": true + }, + "node_modules/chromium-bidi": { + "version": "0.4.7", + "resolved": "https://registry.npmjs.org/chromium-bidi/-/chromium-bidi-0.4.7.tgz", + "integrity": "sha512-6+mJuFXwTMU6I3vYLs6IL8A1DyQTPjCfIL971X0aMPVGRbGnNfl6i6Cl0NMbxi2bRYLGESt9T2ZIMRM5PAEcIQ==", + "dev": true, + "dependencies": { + "mitt": "3.0.0" + }, + "peerDependencies": { + "devtools-protocol": "*" + } + }, + "node_modules/clean-stack": { + "version": "2.2.0", + "resolved": "https://registry.npmjs.org/clean-stack/-/clean-stack-2.2.0.tgz", + "integrity": "sha512-4diC9HaTE+KRAMWhDhrGOECgWZxoevMc5TlkObMqNSsVU62PYzXZ/SMTjzyGAFF1YusgxGcSWTEXBhp0CPwQ1A==", + "dev": true, + "engines": { + "node": ">=6" + } + }, + "node_modules/cliui": { + "version": "6.0.0", + "resolved": "https://registry.npmjs.org/cliui/-/cliui-6.0.0.tgz", + "integrity": "sha512-t6wbgtoCXvAzst7QgXxJYqPt0usEfbgQdftEPbLL/cvv6HPE5VgvqCuAIDR0NgU52ds6rFwqrgakNLrHEjCbrQ==", + "dev": true, + "dependencies": { + "string-width": "^4.2.0", + "strip-ansi": "^6.0.0", + "wrap-ansi": "^6.2.0" + } + }, + "node_modules/color-convert": { + "version": "1.9.3", + "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-1.9.3.tgz", + "integrity": "sha512-QfAUtd+vFdAtFQcC8CCyYt1fYWxSqAiK2cSD6zDB8N3cpsEBAvRxp9zOGg6G/SHHJYAT88/az/IuDGALsNVbGg==", + "dev": true, + "dependencies": { + "color-name": "1.1.3" + } + }, + "node_modules/color-name": { + "version": "1.1.3", + "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.3.tgz", + "integrity": "sha512-72fSenhMw2HZMTVHeCA9KCmpEIbzWiQsjN+BHcBbS9vr1mtt+vJjPdksIBNUmKAW8TFUDPJK5SUU3QhE9NEXDw==", + "dev": true + }, + "node_modules/commondir": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/commondir/-/commondir-1.0.1.tgz", + "integrity": "sha512-W9pAhw0ja1Edb5GVdIF1mjZw/ASI0AlShXM83UUGe2DVr5TdAPEA1OA8m/g8zWp9x6On7gqufY+FatDbC3MDQg==", + "dev": true + }, + "node_modules/concat-map": { + "version": "0.0.1", + "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", + "integrity": "sha512-/Srv4dswyQNBfohGpz9o6Yb3Gz3SrUDqBH5rTuhGR7ahtlbYKnVxw2bCFMRljaA7EXHaXZ8wsHdodFvbkhKmqg==", + "dev": true + }, + "node_modules/convert-source-map": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/convert-source-map/-/convert-source-map-2.0.0.tgz", + "integrity": "sha512-Kvp459HrV2FEJ1CAsi1Ku+MY3kasH19TFykTz2xWmMeq6bk2NU3XXvfJ+Q61m0xktWwt+1HSYf3JZsTms3aRJg==", + "dev": true + }, + "node_modules/cosmiconfig": { + "version": "8.1.3", + "resolved": "https://registry.npmjs.org/cosmiconfig/-/cosmiconfig-8.1.3.tgz", + "integrity": "sha512-/UkO2JKI18b5jVMJUp0lvKFMpa/Gye+ZgZjKD+DGEN9y7NRcf/nK1A0sp67ONmKtnDCNMS44E6jrk0Yc3bDuUw==", + "dev": true, + "dependencies": { + "import-fresh": "^3.2.1", + "js-yaml": "^4.1.0", + "parse-json": "^5.0.0", + "path-type": "^4.0.0" + }, + "engines": { + "node": ">=14" + }, + "funding": { + "url": "https://github.com/sponsors/d-fischer" + } + }, + "node_modules/cosmiconfig/node_modules/argparse": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/argparse/-/argparse-2.0.1.tgz", + "integrity": "sha512-8+9WqebbFzpX9OR+Wa6O29asIogeRMzcGtAINdpMHHyAg10f05aSFVBbcEqGf/PXw1EjAZ+q2/bEBg3DvurK3Q==", + "dev": true + }, + "node_modules/cosmiconfig/node_modules/js-yaml": { + "version": "4.1.0", + "resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-4.1.0.tgz", + "integrity": "sha512-wpxZs9NoxZaJESJGIZTyDEaYpl0FKSA+FB9aJiyemKhMwkxQg63h4T1KJgUGHpTqPDNRcmmYLugrRjJlBtWvRA==", + "dev": true, + "dependencies": { + "argparse": "^2.0.1" + }, + "bin": { + "js-yaml": "bin/js-yaml.js" + } + }, + "node_modules/cross-fetch": { + "version": "3.1.5", + "resolved": "https://registry.npmjs.org/cross-fetch/-/cross-fetch-3.1.5.tgz", + "integrity": "sha512-lvb1SBsI0Z7GDwmuid+mU3kWVBwTVUbe7S0H52yaaAdQOXq2YktTCZdlAcNKFzE6QtRz0snpw9bNiPeOIkkQvw==", + "dev": true, + "dependencies": { + "node-fetch": "2.6.7" + } + }, + "node_modules/cross-spawn": { + "version": "7.0.3", + "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-7.0.3.tgz", + "integrity": "sha512-iRDPJKUPVEND7dHPO8rkbOnPpyDygcDFtWjpeWNCgy8WP2rXcxXL8TskReQl6OrB2G7+UJrags1q15Fudc7G6w==", + "dev": true, + "dependencies": { + "path-key": "^3.1.0", + "shebang-command": "^2.0.0", + "which": "^2.0.1" + }, + "engines": { + "node": ">= 8" + } + }, + "node_modules/data-view-buffer": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/data-view-buffer/-/data-view-buffer-1.0.1.tgz", + "integrity": "sha512-0lht7OugA5x3iJLOWFhWK/5ehONdprk0ISXqVFn/NFrDu+cuc8iADFrGQz5BnRK7LLU3JmkbXSxaqX+/mXYtUA==", + "dev": true, + "dependencies": { + "call-bind": "^1.0.6", + "es-errors": "^1.3.0", + "is-data-view": "^1.0.1" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/data-view-byte-length": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/data-view-byte-length/-/data-view-byte-length-1.0.1.tgz", + "integrity": "sha512-4J7wRJD3ABAzr8wP+OcIcqq2dlUKp4DVflx++hs5h5ZKydWMI6/D/fAot+yh6g2tHh8fLFTvNOaVN357NvSrOQ==", + "dev": true, + "dependencies": { + "call-bind": "^1.0.7", + "es-errors": "^1.3.0", + "is-data-view": "^1.0.1" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/data-view-byte-offset": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/data-view-byte-offset/-/data-view-byte-offset-1.0.0.tgz", + "integrity": "sha512-t/Ygsytq+R995EJ5PZlD4Cu56sWa8InXySaViRzw9apusqsOO2bQP+SbYzAhR0pFKoB+43lYy8rWban9JSuXnA==", + "dev": true, + "dependencies": { + "call-bind": "^1.0.6", + "es-errors": "^1.3.0", + "is-data-view": "^1.0.1" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/debug": { + "version": "4.3.6", + "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.6.tgz", + "integrity": "sha512-O/09Bd4Z1fBrU4VzkhFqVgpPzaGbw6Sm9FEkBT1A/YBXQFGuuSxa1dN2nxgxS34JmKXqYx8CZAwEVoJFImUXIg==", + "dev": true, + "dependencies": { + "ms": "2.1.2" + }, + "engines": { + "node": ">=6.0" + }, + "peerDependenciesMeta": { + "supports-color": { + "optional": true + } + } + }, + "node_modules/decamelize": { + "version": "1.2.0", + "resolved": "https://registry.npmjs.org/decamelize/-/decamelize-1.2.0.tgz", + "integrity": "sha512-z2S+W9X73hAUUki+N+9Za2lBlun89zigOyGrsax+KUQ6wKW4ZoWpEYBkGhQjwAjjDCkWxhY0VKEhk8wzY7F5cA==", + "dev": true, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/deep-eql": { + "version": "4.1.4", + "resolved": "https://registry.npmjs.org/deep-eql/-/deep-eql-4.1.4.tgz", + "integrity": "sha512-SUwdGfqdKOwxCPeVYjwSyRpJ7Z+fhpwIAtmCUdZIWZ/YP5R9WAsyuSgpLVDi9bjWoN2LXHNss/dk3urXtdQxGg==", + "dev": true, + "dependencies": { + "type-detect": "^4.0.0" + }, + "engines": { + "node": ">=6" + } + }, + "node_modules/deep-is": { + "version": "0.1.4", + "resolved": "https://registry.npmjs.org/deep-is/-/deep-is-0.1.4.tgz", + "integrity": "sha512-oIPzksmTg4/MriiaYGO+okXDT7ztn/w3Eptv/+gSIdMdKsJo0u4CfYNFJPy+4SKMuCqGw2wxnA+URMg3t8a/bQ==", + "dev": true + }, + "node_modules/default-require-extensions": { + "version": "3.0.1", + "resolved": "https://registry.npmjs.org/default-require-extensions/-/default-require-extensions-3.0.1.tgz", + "integrity": "sha512-eXTJmRbm2TIt9MgWTsOH1wEuhew6XGZcMeGKCtLedIg/NCsg1iBePXkceTdK4Fii7pzmN9tGsZhKzZ4h7O/fxw==", + "dev": true, + "dependencies": { + "strip-bom": "^4.0.0" + }, + "engines": { + "node": ">=8" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/define-data-property": { + "version": "1.1.4", + "resolved": "https://registry.npmjs.org/define-data-property/-/define-data-property-1.1.4.tgz", + "integrity": "sha512-rBMvIzlpA8v6E+SJZoo++HAYqsLrkg7MSfIinMPFhmkorw7X+dOXVJQs+QT69zGkzMyfDnIMN2Wid1+NbL3T+A==", + "dev": true, + "dependencies": { + "es-define-property": "^1.0.0", + "es-errors": "^1.3.0", + "gopd": "^1.0.1" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/define-properties": { + "version": "1.2.1", + "resolved": "https://registry.npmjs.org/define-properties/-/define-properties-1.2.1.tgz", + "integrity": "sha512-8QmQKqEASLd5nx0U1B1okLElbUuuttJ/AnYmRXbbbGDWh6uS208EjD4Xqq/I9wK7u0v6O08XhTWnt5XtEbR6Dg==", + "dev": true, + "dependencies": { + "define-data-property": "^1.0.1", + "has-property-descriptors": "^1.0.0", + "object-keys": "^1.1.1" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/devtools-protocol": { + "version": "0.0.1107588", + "resolved": "https://registry.npmjs.org/devtools-protocol/-/devtools-protocol-0.0.1107588.tgz", + "integrity": "sha512-yIR+pG9x65Xko7bErCUSQaDLrO/P1p3JUzEk7JCU4DowPcGHkTGUGQapcfcLc4qj0UaALwZ+cr0riFgiqpixcg==", + "dev": true + }, + "node_modules/doctrine": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/doctrine/-/doctrine-3.0.0.tgz", + "integrity": "sha512-yS+Q5i3hBf7GBkd4KG8a7eBNNWNGLTaEwwYWUijIYM7zrlYDM0BFXHjjPWlWZ1Rg7UaddZeIDmi9jF3HmqiQ2w==", + "dev": true, + "dependencies": { + "esutils": "^2.0.2" + }, + "engines": { + "node": ">=6.0.0" + } + }, + "node_modules/electron-to-chromium": { + "version": "1.5.13", + "resolved": "https://registry.npmjs.org/electron-to-chromium/-/electron-to-chromium-1.5.13.tgz", + "integrity": "sha512-lbBcvtIJ4J6sS4tb5TLp1b4LyfCdMkwStzXPyAgVgTRAsep4bvrAGaBOP7ZJtQMNJpSQ9SqG4brWOroNaQtm7Q==", + "dev": true + }, + "node_modules/emoji-regex": { + "version": "8.0.0", + "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-8.0.0.tgz", + "integrity": "sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==", + "dev": true + }, + "node_modules/end-of-stream": { + "version": "1.4.4", + "resolved": "https://registry.npmjs.org/end-of-stream/-/end-of-stream-1.4.4.tgz", + "integrity": "sha512-+uw1inIHVPQoaVuHzRyXd21icM+cnt4CzD5rW+NC1wjOUSTOs+Te7FOv7AhN7vS9x/oIyhLP5PR1H+phQAHu5Q==", + "dev": true, + "dependencies": { + "once": "^1.4.0" + } + }, + "node_modules/error-ex": { + "version": "1.3.2", + "resolved": "https://registry.npmjs.org/error-ex/-/error-ex-1.3.2.tgz", + "integrity": "sha512-7dFHNmqeFSEt2ZBsCriorKnn3Z2pj+fd9kmI6QoWw4//DL+icEBfc0U7qJCisqrTsKTjw4fNFy2pW9OqStD84g==", + "dev": true, + "dependencies": { + "is-arrayish": "^0.2.1" + } + }, + "node_modules/es-abstract": { + "version": "1.23.3", + "resolved": "https://registry.npmjs.org/es-abstract/-/es-abstract-1.23.3.tgz", + "integrity": "sha512-e+HfNH61Bj1X9/jLc5v1owaLYuHdeHHSQlkhCBiTK8rBvKaULl/beGMxwrMXjpYrv4pz22BlY570vVePA2ho4A==", + "dev": true, + "dependencies": { + "array-buffer-byte-length": "^1.0.1", + "arraybuffer.prototype.slice": "^1.0.3", + "available-typed-arrays": "^1.0.7", + "call-bind": "^1.0.7", + "data-view-buffer": "^1.0.1", + "data-view-byte-length": "^1.0.1", + "data-view-byte-offset": "^1.0.0", + "es-define-property": "^1.0.0", + "es-errors": "^1.3.0", + "es-object-atoms": "^1.0.0", + "es-set-tostringtag": "^2.0.3", + "es-to-primitive": "^1.2.1", + "function.prototype.name": "^1.1.6", + "get-intrinsic": "^1.2.4", + "get-symbol-description": "^1.0.2", + "globalthis": "^1.0.3", + "gopd": "^1.0.1", + "has-property-descriptors": "^1.0.2", + "has-proto": "^1.0.3", + "has-symbols": "^1.0.3", + "hasown": "^2.0.2", + "internal-slot": "^1.0.7", + "is-array-buffer": "^3.0.4", + "is-callable": "^1.2.7", + "is-data-view": "^1.0.1", + "is-negative-zero": "^2.0.3", + "is-regex": "^1.1.4", + "is-shared-array-buffer": "^1.0.3", + "is-string": "^1.0.7", + "is-typed-array": "^1.1.13", + "is-weakref": "^1.0.2", + "object-inspect": "^1.13.1", + "object-keys": "^1.1.1", + "object.assign": "^4.1.5", + "regexp.prototype.flags": "^1.5.2", + "safe-array-concat": "^1.1.2", + "safe-regex-test": "^1.0.3", + "string.prototype.trim": "^1.2.9", + "string.prototype.trimend": "^1.0.8", + "string.prototype.trimstart": "^1.0.8", + "typed-array-buffer": "^1.0.2", + "typed-array-byte-length": "^1.0.1", + "typed-array-byte-offset": "^1.0.2", + "typed-array-length": "^1.0.6", + "unbox-primitive": "^1.0.2", + "which-typed-array": "^1.1.15" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/es-define-property": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/es-define-property/-/es-define-property-1.0.0.tgz", + "integrity": "sha512-jxayLKShrEqqzJ0eumQbVhTYQM27CfT1T35+gCgDFoL82JLsXqTJ76zv6A0YLOgEnLUMvLzsDsGIrl8NFpT2gQ==", + "dev": true, + "dependencies": { + "get-intrinsic": "^1.2.4" + }, + "engines": { + "node": ">= 0.4" + } + }, + "node_modules/es-errors": { + "version": "1.3.0", + "resolved": "https://registry.npmjs.org/es-errors/-/es-errors-1.3.0.tgz", + "integrity": "sha512-Zf5H2Kxt2xjTvbJvP2ZWLEICxA6j+hAmMzIlypy4xcBg1vKVnx89Wy0GbS+kf5cwCVFFzdCFh2XSCFNULS6csw==", + "dev": true, + "engines": { + "node": ">= 0.4" + } + }, + "node_modules/es-iterator-helpers": { + "version": "1.0.19", + "resolved": "https://registry.npmjs.org/es-iterator-helpers/-/es-iterator-helpers-1.0.19.tgz", + "integrity": "sha512-zoMwbCcH5hwUkKJkT8kDIBZSz9I6mVG//+lDCinLCGov4+r7NIy0ld8o03M0cJxl2spVf6ESYVS6/gpIfq1FFw==", + "dev": true, + "dependencies": { + "call-bind": "^1.0.7", + "define-properties": "^1.2.1", + "es-abstract": "^1.23.3", + "es-errors": "^1.3.0", + "es-set-tostringtag": "^2.0.3", + "function-bind": "^1.1.2", + "get-intrinsic": "^1.2.4", + "globalthis": "^1.0.3", + "has-property-descriptors": "^1.0.2", + "has-proto": "^1.0.3", + "has-symbols": "^1.0.3", + "internal-slot": "^1.0.7", + "iterator.prototype": "^1.1.2", + "safe-array-concat": "^1.1.2" + }, + "engines": { + "node": ">= 0.4" + } + }, + "node_modules/es-object-atoms": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/es-object-atoms/-/es-object-atoms-1.0.0.tgz", + "integrity": "sha512-MZ4iQ6JwHOBQjahnjwaC1ZtIBH+2ohjamzAO3oaHcXYup7qxjF2fixyH+Q71voWHeOkI2q/TnJao/KfXYIZWbw==", + "dev": true, + "dependencies": { + "es-errors": "^1.3.0" + }, + "engines": { + "node": ">= 0.4" + } + }, + "node_modules/es-set-tostringtag": { + "version": "2.0.3", + "resolved": "https://registry.npmjs.org/es-set-tostringtag/-/es-set-tostringtag-2.0.3.tgz", + "integrity": "sha512-3T8uNMC3OQTHkFUsFq8r/BwAXLHvU/9O9mE0fBc/MY5iq/8H7ncvO947LmYA6ldWw9Uh8Yhf25zu6n7nML5QWQ==", + "dev": true, + "dependencies": { + "get-intrinsic": "^1.2.4", + "has-tostringtag": "^1.0.2", + "hasown": "^2.0.1" + }, + "engines": { + "node": ">= 0.4" + } + }, + "node_modules/es-shim-unscopables": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/es-shim-unscopables/-/es-shim-unscopables-1.0.2.tgz", + "integrity": "sha512-J3yBRXCzDu4ULnQwxyToo/OjdMx6akgVC7K6few0a7F/0wLtmKKN7I73AH5T2836UuXRqN7Qg+IIUw/+YJksRw==", + "dev": true, + "dependencies": { + "hasown": "^2.0.0" + } + }, + "node_modules/es-to-primitive": { + "version": "1.2.1", + "resolved": "https://registry.npmjs.org/es-to-primitive/-/es-to-primitive-1.2.1.tgz", + "integrity": "sha512-QCOllgZJtaUo9miYBcLChTUaHNjJF3PYs1VidD7AwiEj1kYxKeQTctLAezAOH5ZKRH0g2IgPn6KwB4IT8iRpvA==", + "dev": true, + "dependencies": { + "is-callable": "^1.1.4", + "is-date-object": "^1.0.1", + "is-symbol": "^1.0.2" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/es6-error": { + "version": "4.1.1", + "resolved": "https://registry.npmjs.org/es6-error/-/es6-error-4.1.1.tgz", + "integrity": "sha512-Um/+FxMr9CISWh0bi5Zv0iOD+4cFh5qLeks1qhAopKVAJw3drgKbKySikp7wGhDL0HPeaja0P5ULZrxLkniUVg==", + "dev": true + }, + "node_modules/escalade": { + "version": "3.2.0", + "resolved": "https://registry.npmjs.org/escalade/-/escalade-3.2.0.tgz", + "integrity": "sha512-WUj2qlxaQtO4g6Pq5c29GTcWGDyd8itL8zTlipgECz3JesAiiOKotd8JU6otB3PACgG6xkJUyVhboMS+bje/jA==", + "dev": true, + "engines": { + "node": ">=6" + } + }, + "node_modules/escape-string-regexp": { + "version": "1.0.5", + "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-1.0.5.tgz", + "integrity": "sha512-vbRorB5FUQWvla16U8R/qgaFIya2qGzwDrNmCZuYKrbdSUMG6I1ZCGQRefkRVhuOkIGVne7BQ35DSfo1qvJqFg==", + "dev": true, + "engines": { + "node": ">=0.8.0" + } + }, + "node_modules/eslint": { + "version": "8.57.0", + "resolved": "https://registry.npmjs.org/eslint/-/eslint-8.57.0.tgz", + "integrity": "sha512-dZ6+mexnaTIbSBZWgou51U6OmzIhYM2VcNdtiTtI7qPNZm35Akpr0f6vtw3w1Kmn5PYo+tZVfh13WrhpS6oLqQ==", + "dev": true, + "dependencies": { + "@eslint-community/eslint-utils": "^4.2.0", + "@eslint-community/regexpp": "^4.6.1", + "@eslint/eslintrc": "^2.1.4", + "@eslint/js": "8.57.0", + "@humanwhocodes/config-array": "^0.11.14", + "@humanwhocodes/module-importer": "^1.0.1", + "@nodelib/fs.walk": "^1.2.8", + "@ungap/structured-clone": "^1.2.0", + "ajv": "^6.12.4", + "chalk": "^4.0.0", + "cross-spawn": "^7.0.2", + "debug": "^4.3.2", + "doctrine": "^3.0.0", + "escape-string-regexp": "^4.0.0", + "eslint-scope": "^7.2.2", + "eslint-visitor-keys": "^3.4.3", + "espree": "^9.6.1", + "esquery": "^1.4.2", + "esutils": "^2.0.2", + "fast-deep-equal": "^3.1.3", + "file-entry-cache": "^6.0.1", + "find-up": "^5.0.0", + "glob-parent": "^6.0.2", + "globals": "^13.19.0", + "graphemer": "^1.4.0", + "ignore": "^5.2.0", + "imurmurhash": "^0.1.4", + "is-glob": "^4.0.0", + "is-path-inside": "^3.0.3", + "js-yaml": "^4.1.0", + "json-stable-stringify-without-jsonify": "^1.0.1", + "levn": "^0.4.1", + "lodash.merge": "^4.6.2", + "minimatch": "^3.1.2", + "natural-compare": "^1.4.0", + "optionator": "^0.9.3", + "strip-ansi": "^6.0.1", + "text-table": "^0.2.0" + }, + "bin": { + "eslint": "bin/eslint.js" + }, + "engines": { + "node": "^12.22.0 || ^14.17.0 || >=16.0.0" + }, + "funding": { + "url": "https://opencollective.com/eslint" + } + }, + "node_modules/eslint-config-standard": { + "version": "17.1.0", + "resolved": "https://registry.npmjs.org/eslint-config-standard/-/eslint-config-standard-17.1.0.tgz", + "integrity": "sha512-IwHwmaBNtDK4zDHQukFDW5u/aTb8+meQWZvNFWkiGmbWjD6bqyuSSBxxXKkCftCUzc1zwCH2m/baCNDLGmuO5Q==", + "dev": true, + "funding": [ + { + "type": "github", + "url": "https://github.com/sponsors/feross" + }, + { + "type": "patreon", + "url": "https://www.patreon.com/feross" + }, + { + "type": "consulting", + "url": "https://feross.org/support" + } + ], + "engines": { + "node": ">=12.0.0" + }, + "peerDependencies": { + "eslint": "^8.0.1", + "eslint-plugin-import": "^2.25.2", + "eslint-plugin-n": "^15.0.0 || ^16.0.0 ", + "eslint-plugin-promise": "^6.0.0" + } + }, + "node_modules/eslint-config-standard-jsx": { + "version": "11.0.0", + "resolved": "https://registry.npmjs.org/eslint-config-standard-jsx/-/eslint-config-standard-jsx-11.0.0.tgz", + "integrity": "sha512-+1EV/R0JxEK1L0NGolAr8Iktm3Rgotx3BKwgaX+eAuSX8D952LULKtjgZD3F+e6SvibONnhLwoTi9DPxN5LvvQ==", + "dev": true, + "funding": [ + { + "type": "github", + "url": "https://github.com/sponsors/feross" + }, + { + "type": "patreon", + "url": "https://www.patreon.com/feross" + }, + { + "type": "consulting", + "url": "https://feross.org/support" + } + ], + "peerDependencies": { + "eslint": "^8.8.0", + "eslint-plugin-react": "^7.28.0" + } + }, + "node_modules/eslint-import-resolver-node": { + "version": "0.3.9", + "resolved": "https://registry.npmjs.org/eslint-import-resolver-node/-/eslint-import-resolver-node-0.3.9.tgz", + "integrity": "sha512-WFj2isz22JahUv+B788TlO3N6zL3nNJGU8CcZbPZvVEkBPaJdCV4vy5wyghty5ROFbCRnm132v8BScu5/1BQ8g==", + "dev": true, + "dependencies": { + "debug": "^3.2.7", + "is-core-module": "^2.13.0", + "resolve": "^1.22.4" + } + }, + "node_modules/eslint-import-resolver-node/node_modules/debug": { + "version": "3.2.7", + "resolved": "https://registry.npmjs.org/debug/-/debug-3.2.7.tgz", + "integrity": "sha512-CFjzYYAi4ThfiQvizrFQevTTXHtnCqWfe7x1AhgEscTz6ZbLbfoLRLPugTQyBth6f8ZERVUSyWHFD/7Wu4t1XQ==", + "dev": true, + "dependencies": { + "ms": "^2.1.1" + } + }, + "node_modules/eslint-module-utils": { + "version": "2.8.2", + "resolved": "https://registry.npmjs.org/eslint-module-utils/-/eslint-module-utils-2.8.2.tgz", + "integrity": "sha512-3XnC5fDyc8M4J2E8pt8pmSVRX2M+5yWMCfI/kDZwauQeFgzQOuhcRBFKjTeJagqgk4sFKxe1mvNVnaWwImx/Tg==", + "dev": true, + "dependencies": { + "debug": "^3.2.7" + }, + "engines": { + "node": ">=4" + }, + "peerDependenciesMeta": { + "eslint": { + "optional": true + } + } + }, + "node_modules/eslint-module-utils/node_modules/debug": { + "version": "3.2.7", + "resolved": "https://registry.npmjs.org/debug/-/debug-3.2.7.tgz", + "integrity": "sha512-CFjzYYAi4ThfiQvizrFQevTTXHtnCqWfe7x1AhgEscTz6ZbLbfoLRLPugTQyBth6f8ZERVUSyWHFD/7Wu4t1XQ==", + "dev": true, + "dependencies": { + "ms": "^2.1.1" + } + }, + "node_modules/eslint-plugin-es": { + "version": "4.1.0", + "resolved": "https://registry.npmjs.org/eslint-plugin-es/-/eslint-plugin-es-4.1.0.tgz", + "integrity": "sha512-GILhQTnjYE2WorX5Jyi5i4dz5ALWxBIdQECVQavL6s7cI76IZTDWleTHkxz/QT3kvcs2QlGHvKLYsSlPOlPXnQ==", + "dev": true, + "dependencies": { + "eslint-utils": "^2.0.0", + "regexpp": "^3.0.0" + }, + "engines": { + "node": ">=8.10.0" + }, + "funding": { + "url": "https://github.com/sponsors/mysticatea" + }, + "peerDependencies": { + "eslint": ">=4.19.1" + } + }, + "node_modules/eslint-plugin-es/node_modules/eslint-utils": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/eslint-utils/-/eslint-utils-2.1.0.tgz", + "integrity": "sha512-w94dQYoauyvlDc43XnGB8lU3Zt713vNChgt4EWwhXAP2XkBvndfxF0AgIqKOOasjPIPzj9JqgwkwbCYD0/V3Zg==", + "dev": true, + "dependencies": { + "eslint-visitor-keys": "^1.1.0" + }, + "engines": { + "node": ">=6" + }, + "funding": { + "url": "https://github.com/sponsors/mysticatea" + } + }, + "node_modules/eslint-plugin-es/node_modules/eslint-visitor-keys": { + "version": "1.3.0", + "resolved": "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-1.3.0.tgz", + "integrity": "sha512-6J72N8UNa462wa/KFODt/PJ3IU60SDpC3QXC1Hjc1BXXpfL2C9R5+AU7jhe0F6GREqVMh4Juu+NY7xn+6dipUQ==", + "dev": true, + "engines": { + "node": ">=4" + } + }, + "node_modules/eslint-plugin-import": { + "version": "2.29.1", + "resolved": "https://registry.npmjs.org/eslint-plugin-import/-/eslint-plugin-import-2.29.1.tgz", + "integrity": "sha512-BbPC0cuExzhiMo4Ff1BTVwHpjjv28C5R+btTOGaCRC7UEz801up0JadwkeSk5Ued6TG34uaczuVuH6qyy5YUxw==", + "dev": true, + "dependencies": { + "array-includes": "^3.1.7", + "array.prototype.findlastindex": "^1.2.3", + "array.prototype.flat": "^1.3.2", + "array.prototype.flatmap": "^1.3.2", + "debug": "^3.2.7", + "doctrine": "^2.1.0", + "eslint-import-resolver-node": "^0.3.9", + "eslint-module-utils": "^2.8.0", + "hasown": "^2.0.0", + "is-core-module": "^2.13.1", + "is-glob": "^4.0.3", + "minimatch": "^3.1.2", + "object.fromentries": "^2.0.7", + "object.groupby": "^1.0.1", + "object.values": "^1.1.7", + "semver": "^6.3.1", + "tsconfig-paths": "^3.15.0" + }, + "engines": { + "node": ">=4" + }, + "peerDependencies": { + "eslint": "^2 || ^3 || ^4 || ^5 || ^6 || ^7.2.0 || ^8" + } + }, + "node_modules/eslint-plugin-import/node_modules/debug": { + "version": "3.2.7", + "resolved": "https://registry.npmjs.org/debug/-/debug-3.2.7.tgz", + "integrity": "sha512-CFjzYYAi4ThfiQvizrFQevTTXHtnCqWfe7x1AhgEscTz6ZbLbfoLRLPugTQyBth6f8ZERVUSyWHFD/7Wu4t1XQ==", + "dev": true, + "dependencies": { + "ms": "^2.1.1" + } + }, + "node_modules/eslint-plugin-import/node_modules/doctrine": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/doctrine/-/doctrine-2.1.0.tgz", + "integrity": "sha512-35mSku4ZXK0vfCuHEDAwt55dg2jNajHZ1odvF+8SSr82EsZY4QmXfuWso8oEd8zRhVObSN18aM0CjSdoBX7zIw==", + "dev": true, + "dependencies": { + "esutils": "^2.0.2" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/eslint-plugin-n": { + "version": "15.7.0", + "resolved": "https://registry.npmjs.org/eslint-plugin-n/-/eslint-plugin-n-15.7.0.tgz", + "integrity": "sha512-jDex9s7D/Qial8AGVIHq4W7NswpUD5DPDL2RH8Lzd9EloWUuvUkHfv4FRLMipH5q2UtyurorBkPeNi1wVWNh3Q==", + "dev": true, + "dependencies": { + "builtins": "^5.0.1", + "eslint-plugin-es": "^4.1.0", + "eslint-utils": "^3.0.0", + "ignore": "^5.1.1", + "is-core-module": "^2.11.0", + "minimatch": "^3.1.2", + "resolve": "^1.22.1", + "semver": "^7.3.8" + }, + "engines": { + "node": ">=12.22.0" + }, + "funding": { + "url": "https://github.com/sponsors/mysticatea" + }, + "peerDependencies": { + "eslint": ">=7.0.0" + } + }, + "node_modules/eslint-plugin-n/node_modules/semver": { + "version": "7.6.3", + "resolved": "https://registry.npmjs.org/semver/-/semver-7.6.3.tgz", + "integrity": "sha512-oVekP1cKtI+CTDvHWYFUcMtsK/00wmAEfyqKfNdARm8u1wNVhSgaX7A8d4UuIlUI5e84iEwOhs7ZPYRmzU9U6A==", + "dev": true, + "bin": { + "semver": "bin/semver.js" + }, + "engines": { + "node": ">=10" + } + }, + "node_modules/eslint-plugin-promise": { + "version": "6.6.0", + "resolved": "https://registry.npmjs.org/eslint-plugin-promise/-/eslint-plugin-promise-6.6.0.tgz", + "integrity": "sha512-57Zzfw8G6+Gq7axm2Pdo3gW/Rx3h9Yywgn61uE/3elTCOePEHVrn2i5CdfBwA1BLK0Q0WqctICIUSqXZW/VprQ==", + "dev": true, + "engines": { + "node": "^12.22.0 || ^14.17.0 || >=16.0.0" + }, + "funding": { + "url": "https://opencollective.com/eslint" + }, + "peerDependencies": { + "eslint": "^7.0.0 || ^8.0.0 || ^9.0.0" + } + }, + "node_modules/eslint-plugin-react": { + "version": "7.35.0", + "resolved": "https://registry.npmjs.org/eslint-plugin-react/-/eslint-plugin-react-7.35.0.tgz", + "integrity": "sha512-v501SSMOWv8gerHkk+IIQBkcGRGrO2nfybfj5pLxuJNFTPxxA3PSryhXTK+9pNbtkggheDdsC0E9Q8CuPk6JKA==", + "dev": true, + "dependencies": { + "array-includes": "^3.1.8", + "array.prototype.findlast": "^1.2.5", + "array.prototype.flatmap": "^1.3.2", + "array.prototype.tosorted": "^1.1.4", + "doctrine": "^2.1.0", + "es-iterator-helpers": "^1.0.19", + "estraverse": "^5.3.0", + "hasown": "^2.0.2", + "jsx-ast-utils": "^2.4.1 || ^3.0.0", + "minimatch": "^3.1.2", + "object.entries": "^1.1.8", + "object.fromentries": "^2.0.8", + "object.values": "^1.2.0", + "prop-types": "^15.8.1", + "resolve": "^2.0.0-next.5", + "semver": "^6.3.1", + "string.prototype.matchall": "^4.0.11", + "string.prototype.repeat": "^1.0.0" + }, + "engines": { + "node": ">=4" + }, + "peerDependencies": { + "eslint": "^3 || ^4 || ^5 || ^6 || ^7 || ^8 || ^9.7" + } + }, + "node_modules/eslint-plugin-react/node_modules/doctrine": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/doctrine/-/doctrine-2.1.0.tgz", + "integrity": "sha512-35mSku4ZXK0vfCuHEDAwt55dg2jNajHZ1odvF+8SSr82EsZY4QmXfuWso8oEd8zRhVObSN18aM0CjSdoBX7zIw==", + "dev": true, + "dependencies": { + "esutils": "^2.0.2" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/eslint-plugin-react/node_modules/resolve": { + "version": "2.0.0-next.5", + "resolved": "https://registry.npmjs.org/resolve/-/resolve-2.0.0-next.5.tgz", + "integrity": "sha512-U7WjGVG9sH8tvjW5SmGbQuui75FiyjAX72HX15DwBBwF9dNiQZRQAg9nnPhYy+TUnE0+VcrttuvNI8oSxZcocA==", + "dev": true, + "dependencies": { + "is-core-module": "^2.13.0", + "path-parse": "^1.0.7", + "supports-preserve-symlinks-flag": "^1.0.0" + }, + "bin": { + "resolve": "bin/resolve" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/eslint-scope": { + "version": "7.2.2", + "resolved": "https://registry.npmjs.org/eslint-scope/-/eslint-scope-7.2.2.tgz", + "integrity": "sha512-dOt21O7lTMhDM+X9mB4GX+DZrZtCUJPL/wlcTqxyrx5IvO0IYtILdtrQGQp+8n5S0gwSVmOf9NQrjMOgfQZlIg==", + "dev": true, + "dependencies": { + "esrecurse": "^4.3.0", + "estraverse": "^5.2.0" + }, + "engines": { + "node": "^12.22.0 || ^14.17.0 || >=16.0.0" + }, + "funding": { + "url": "https://opencollective.com/eslint" + } + }, + "node_modules/eslint-utils": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/eslint-utils/-/eslint-utils-3.0.0.tgz", + "integrity": "sha512-uuQC43IGctw68pJA1RgbQS8/NP7rch6Cwd4j3ZBtgo4/8Flj4eGE7ZYSZRN3iq5pVUv6GPdW5Z1RFleo84uLDA==", + "dev": true, + "dependencies": { + "eslint-visitor-keys": "^2.0.0" + }, + "engines": { + "node": "^10.0.0 || ^12.0.0 || >= 14.0.0" + }, + "funding": { + "url": "https://github.com/sponsors/mysticatea" + }, + "peerDependencies": { + "eslint": ">=5" + } + }, + "node_modules/eslint-utils/node_modules/eslint-visitor-keys": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-2.1.0.tgz", + "integrity": "sha512-0rSmRBzXgDzIsD6mGdJgevzgezI534Cer5L/vyMX0kHzT/jiB43jRhd9YUlMGYLQy2zprNmoT8qasCGtY+QaKw==", + "dev": true, + "engines": { + "node": ">=10" + } + }, + "node_modules/eslint-visitor-keys": { + "version": "3.4.3", + "resolved": "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-3.4.3.tgz", + "integrity": "sha512-wpc+LXeiyiisxPlEkUzU6svyS1frIO3Mgxj1fdy7Pm8Ygzguax2N3Fa/D/ag1WqbOprdI+uY6wMUl8/a2G+iag==", + "dev": true, + "engines": { + "node": "^12.22.0 || ^14.17.0 || >=16.0.0" + }, + "funding": { + "url": "https://opencollective.com/eslint" + } + }, + "node_modules/eslint/node_modules/ansi-styles": { + "version": "4.3.0", + "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", + "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", + "dev": true, + "dependencies": { + "color-convert": "^2.0.1" + }, + "engines": { + "node": ">=8" + }, + "funding": { + "url": "https://github.com/chalk/ansi-styles?sponsor=1" + } + }, + "node_modules/eslint/node_modules/argparse": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/argparse/-/argparse-2.0.1.tgz", + "integrity": "sha512-8+9WqebbFzpX9OR+Wa6O29asIogeRMzcGtAINdpMHHyAg10f05aSFVBbcEqGf/PXw1EjAZ+q2/bEBg3DvurK3Q==", + "dev": true + }, + "node_modules/eslint/node_modules/chalk": { + "version": "4.1.2", + "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.2.tgz", + "integrity": "sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA==", + "dev": true, + "dependencies": { + "ansi-styles": "^4.1.0", + "supports-color": "^7.1.0" + }, + "engines": { + "node": ">=10" + }, + "funding": { + "url": "https://github.com/chalk/chalk?sponsor=1" + } + }, + "node_modules/eslint/node_modules/color-convert": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", + "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", + "dev": true, + "dependencies": { + "color-name": "~1.1.4" + }, + "engines": { + "node": ">=7.0.0" + } + }, + "node_modules/eslint/node_modules/color-name": { + "version": "1.1.4", + "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", + "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", + "dev": true + }, + "node_modules/eslint/node_modules/escape-string-regexp": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-4.0.0.tgz", + "integrity": "sha512-TtpcNJ3XAzx3Gq8sWRzJaVajRs0uVxA2YAkdb1jm2YkPz4G6egUFAyA3n5vtEIZefPk5Wa4UXbKuS5fKkJWdgA==", + "dev": true, + "engines": { + "node": ">=10" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/eslint/node_modules/find-up": { + "version": "5.0.0", + "resolved": "https://registry.npmjs.org/find-up/-/find-up-5.0.0.tgz", + "integrity": "sha512-78/PXT1wlLLDgTzDs7sjq9hzz0vXD+zn+7wypEe4fXQxCmdmqfGsEPQxmiCSQI3ajFV91bVSsvNtrJRiW6nGng==", + "dev": true, + "dependencies": { + "locate-path": "^6.0.0", + "path-exists": "^4.0.0" + }, + "engines": { + "node": ">=10" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/eslint/node_modules/globals": { + "version": "13.24.0", + "resolved": "https://registry.npmjs.org/globals/-/globals-13.24.0.tgz", + "integrity": "sha512-AhO5QUcj8llrbG09iWhPU2B204J1xnPeL8kQmVorSsy+Sjj1sk8gIyh6cUocGmH4L0UuhAJy+hJMRA4mgA4mFQ==", + "dev": true, + "dependencies": { + "type-fest": "^0.20.2" + }, + "engines": { + "node": ">=8" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/eslint/node_modules/has-flag": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", + "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==", + "dev": true, + "engines": { + "node": ">=8" + } + }, + "node_modules/eslint/node_modules/js-yaml": { + "version": "4.1.0", + "resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-4.1.0.tgz", + "integrity": "sha512-wpxZs9NoxZaJESJGIZTyDEaYpl0FKSA+FB9aJiyemKhMwkxQg63h4T1KJgUGHpTqPDNRcmmYLugrRjJlBtWvRA==", + "dev": true, + "dependencies": { + "argparse": "^2.0.1" + }, + "bin": { + "js-yaml": "bin/js-yaml.js" + } + }, + "node_modules/eslint/node_modules/locate-path": { + "version": "6.0.0", + "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-6.0.0.tgz", + "integrity": "sha512-iPZK6eYjbxRu3uB4/WZ3EsEIMJFMqAoopl3R+zuq0UjcAm/MO6KCweDgPfP3elTztoKP3KtnVHxTn2NHBSDVUw==", + "dev": true, + "dependencies": { + "p-locate": "^5.0.0" + }, + "engines": { + "node": ">=10" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/eslint/node_modules/p-limit": { + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-3.1.0.tgz", + "integrity": "sha512-TYOanM3wGwNGsZN2cVTYPArw454xnXj5qmWF1bEoAc4+cU/ol7GVh7odevjp1FNHduHc3KZMcFduxU5Xc6uJRQ==", + "dev": true, + "dependencies": { + "yocto-queue": "^0.1.0" + }, + "engines": { + "node": ">=10" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/eslint/node_modules/p-locate": { + "version": "5.0.0", + "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-5.0.0.tgz", + "integrity": "sha512-LaNjtRWUBY++zB5nE/NwcaoMylSPk+S+ZHNB1TzdbMJMny6dynpAGt7X/tl/QYq3TIeE6nxHppbo2LGymrG5Pw==", + "dev": true, + "dependencies": { + "p-limit": "^3.0.2" + }, + "engines": { + "node": ">=10" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/eslint/node_modules/supports-color": { + "version": "7.2.0", + "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz", + "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==", + "dev": true, + "dependencies": { + "has-flag": "^4.0.0" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/eslint/node_modules/type-fest": { + "version": "0.20.2", + "resolved": "https://registry.npmjs.org/type-fest/-/type-fest-0.20.2.tgz", + "integrity": "sha512-Ne+eE4r0/iWnpAxD852z3A+N0Bt5RN//NjJwRd2VFHEmrywxf5vsZlh4R6lixl6B+wz/8d+maTSAkN1FIkI3LQ==", + "dev": true, + "engines": { + "node": ">=10" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/espree": { + "version": "9.6.1", + "resolved": "https://registry.npmjs.org/espree/-/espree-9.6.1.tgz", + "integrity": "sha512-oruZaFkjorTpF32kDSI5/75ViwGeZginGGy2NoOSg3Q9bnwlnmDm4HLnkl0RE3n+njDXR037aY1+x58Z/zFdwQ==", + "dev": true, + "dependencies": { + "acorn": "^8.9.0", + "acorn-jsx": "^5.3.2", + "eslint-visitor-keys": "^3.4.1" + }, + "engines": { + "node": "^12.22.0 || ^14.17.0 || >=16.0.0" + }, + "funding": { + "url": "https://opencollective.com/eslint" + } + }, + "node_modules/esprima": { + "version": "4.0.1", + "resolved": "https://registry.npmjs.org/esprima/-/esprima-4.0.1.tgz", + "integrity": "sha512-eGuFFw7Upda+g4p+QHvnW0RyTX/SVeJBDM/gCtMARO0cLuT2HcEKnTPvhjV6aGeqrCB/sbNop0Kszm0jsaWU4A==", + "dev": true, + "bin": { + "esparse": "bin/esparse.js", + "esvalidate": "bin/esvalidate.js" + }, + "engines": { + "node": ">=4" + } + }, + "node_modules/esquery": { + "version": "1.6.0", + "resolved": "https://registry.npmjs.org/esquery/-/esquery-1.6.0.tgz", + "integrity": "sha512-ca9pw9fomFcKPvFLXhBKUK90ZvGibiGOvRJNbjljY7s7uq/5YO4BOzcYtJqExdx99rF6aAcnRxHmcUHcz6sQsg==", + "dev": true, + "dependencies": { + "estraverse": "^5.1.0" + }, + "engines": { + "node": ">=0.10" + } + }, + "node_modules/esrecurse": { + "version": "4.3.0", + "resolved": "https://registry.npmjs.org/esrecurse/-/esrecurse-4.3.0.tgz", + "integrity": "sha512-KmfKL3b6G+RXvP8N1vr3Tq1kL/oCFgn2NYXEtqP8/L3pKapUA4G8cFVaoF3SU323CD4XypR/ffioHmkti6/Tag==", + "dev": true, + "dependencies": { + "estraverse": "^5.2.0" + }, + "engines": { + "node": ">=4.0" + } + }, + "node_modules/estraverse": { + "version": "5.3.0", + "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-5.3.0.tgz", + "integrity": "sha512-MMdARuVEQziNTeJD8DgMqmhwR11BRQ/cBP+pLtYdSTnf3MIO8fFeiINEbX36ZdNlfU/7A9f3gUw49B3oQsvwBA==", + "dev": true, + "engines": { + "node": ">=4.0" + } + }, + "node_modules/esutils": { + "version": "2.0.3", + "resolved": "https://registry.npmjs.org/esutils/-/esutils-2.0.3.tgz", + "integrity": "sha512-kVscqXk4OCp68SZ0dkgEKVi6/8ij300KBWTJq32P/dYeWTSwK41WyTxalN1eRmA5Z9UU/LX9D7FWSmV9SAYx6g==", + "dev": true, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/extract-zip": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/extract-zip/-/extract-zip-2.0.1.tgz", + "integrity": "sha512-GDhU9ntwuKyGXdZBUgTIe+vXnWj0fppUEtMDL0+idd5Sta8TGpHssn/eusA9mrPr9qNDym6SxAYZjNvCn/9RBg==", + "dev": true, + "dependencies": { + "debug": "^4.1.1", + "get-stream": "^5.1.0", + "yauzl": "^2.10.0" + }, + "bin": { + "extract-zip": "cli.js" + }, + "engines": { + "node": ">= 10.17.0" + }, + "optionalDependencies": { + "@types/yauzl": "^2.9.1" + } + }, + "node_modules/fast-deep-equal": { + "version": "3.1.3", + "resolved": "https://registry.npmjs.org/fast-deep-equal/-/fast-deep-equal-3.1.3.tgz", + "integrity": "sha512-f3qQ9oQy9j2AhBe/H9VC91wLmKBCCU/gDOnKNAYG5hswO7BLKj09Hc5HYNz9cGI++xlpDCIgDaitVs03ATR84Q==", + "dev": true + }, + "node_modules/fast-json-stable-stringify": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/fast-json-stable-stringify/-/fast-json-stable-stringify-2.1.0.tgz", + "integrity": "sha512-lhd/wF+Lk98HZoTCtlVraHtfh5XYijIjalXck7saUtuanSDyLMxnHhSXEDJqHxD7msR8D0uCmqlkwjCV8xvwHw==", + "dev": true + }, + "node_modules/fast-levenshtein": { + "version": "2.0.6", + "resolved": "https://registry.npmjs.org/fast-levenshtein/-/fast-levenshtein-2.0.6.tgz", + "integrity": "sha512-DCXu6Ifhqcks7TZKY3Hxp3y6qphY5SJZmrWMDrKcERSOXWQdMhU9Ig/PYrzyw/ul9jOIyh0N4M0tbC5hodg8dw==", + "dev": true + }, + "node_modules/fastq": { + "version": "1.17.1", + "resolved": "https://registry.npmjs.org/fastq/-/fastq-1.17.1.tgz", + "integrity": "sha512-sRVD3lWVIXWg6By68ZN7vho9a1pQcN/WBFaAAsDDFzlJjvoGx0P8z7V1t72grFJfJhu3YPZBuu25f7Kaw2jN1w==", + "dev": true, + "dependencies": { + "reusify": "^1.0.4" + } + }, + "node_modules/fd-slicer": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/fd-slicer/-/fd-slicer-1.1.0.tgz", + "integrity": "sha512-cE1qsB/VwyQozZ+q1dGxR8LBYNZeofhEdUNGSMbQD3Gw2lAzX9Zb3uIU6Ebc/Fmyjo9AWWfnn0AUCHqtevs/8g==", + "dev": true, + "dependencies": { + "pend": "~1.2.0" + } + }, + "node_modules/file-entry-cache": { + "version": "6.0.1", + "resolved": "https://registry.npmjs.org/file-entry-cache/-/file-entry-cache-6.0.1.tgz", + "integrity": "sha512-7Gps/XWymbLk2QLYK4NzpMOrYjMhdIxXuIvy2QBsLE6ljuodKvdkWs/cpyJJ3CVIVpH0Oi1Hvg1ovbMzLdFBBg==", + "dev": true, + "dependencies": { + "flat-cache": "^3.0.4" + }, + "engines": { + "node": "^10.12.0 || >=12.0.0" + } + }, + "node_modules/find-cache-dir": { + "version": "3.3.2", + "resolved": "https://registry.npmjs.org/find-cache-dir/-/find-cache-dir-3.3.2.tgz", + "integrity": "sha512-wXZV5emFEjrridIgED11OoUKLxiYjAcqot/NJdAkOhlJ+vGzwhOAfcG5OX1jP+S0PcjEn8bdMJv+g2jwQ3Onig==", + "dev": true, + "dependencies": { + "commondir": "^1.0.1", + "make-dir": "^3.0.2", + "pkg-dir": "^4.1.0" + }, + "engines": { + "node": ">=8" + }, + "funding": { + "url": "https://github.com/avajs/find-cache-dir?sponsor=1" + } + }, + "node_modules/find-up": { + "version": "4.1.0", + "resolved": "https://registry.npmjs.org/find-up/-/find-up-4.1.0.tgz", + "integrity": "sha512-PpOwAdQ/YlXQ2vj8a3h8IipDuYRi3wceVQQGYWxNINccq40Anw7BlsEXCMbt1Zt+OLA6Fq9suIpIWD0OsnISlw==", + "dev": true, + "dependencies": { + "locate-path": "^5.0.0", + "path-exists": "^4.0.0" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/flat-cache": { + "version": "3.2.0", + "resolved": "https://registry.npmjs.org/flat-cache/-/flat-cache-3.2.0.tgz", + "integrity": "sha512-CYcENa+FtcUKLmhhqyctpclsq7QF38pKjZHsGNiSQF5r4FtoKDWabFDl3hzaEQMvT1LHEysw5twgLvpYYb4vbw==", + "dev": true, + "dependencies": { + "flatted": "^3.2.9", + "keyv": "^4.5.3", + "rimraf": "^3.0.2" + }, + "engines": { + "node": "^10.12.0 || >=12.0.0" + } + }, + "node_modules/flatted": { + "version": "3.3.1", + "resolved": "https://registry.npmjs.org/flatted/-/flatted-3.3.1.tgz", + "integrity": "sha512-X8cqMLLie7KsNUDSdzeN8FYK9rEt4Dt67OsG/DNGnYTSDBG4uFAJFBnUeiV+zCVAvwFy56IjM9sH51jVaEhNxw==", + "dev": true + }, + "node_modules/for-each": { + "version": "0.3.3", + "resolved": "https://registry.npmjs.org/for-each/-/for-each-0.3.3.tgz", + "integrity": "sha512-jqYfLp7mo9vIyQf8ykW2v7A+2N4QjeCeI5+Dz9XraiO1ign81wjiH7Fb9vSOWvQfNtmSa4H2RoQTrrXivdUZmw==", + "dev": true, + "dependencies": { + "is-callable": "^1.1.3" + } + }, + "node_modules/foreground-child": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/foreground-child/-/foreground-child-2.0.0.tgz", + "integrity": "sha512-dCIq9FpEcyQyXKCkyzmlPTFNgrCzPudOe+mhvJU5zAtlBnGVy2yKxtfsxK2tQBThwq225jcvBjpw1Gr40uzZCA==", + "dev": true, + "dependencies": { + "cross-spawn": "^7.0.0", + "signal-exit": "^3.0.2" + }, + "engines": { + "node": ">=8.0.0" + } + }, + "node_modules/fromentries": { + "version": "1.3.2", + "resolved": "https://registry.npmjs.org/fromentries/-/fromentries-1.3.2.tgz", + "integrity": "sha512-cHEpEQHUg0f8XdtZCc2ZAhrHzKzT0MrFUTcvx+hfxYu7rGMDc5SKoXFh+n4YigxsHXRzc6OrCshdR1bWH6HHyg==", + "dev": true, + "funding": [ + { + "type": "github", + "url": "https://github.com/sponsors/feross" + }, + { + "type": "patreon", + "url": "https://www.patreon.com/feross" + }, + { + "type": "consulting", + "url": "https://feross.org/support" + } + ] + }, + "node_modules/fs-constants": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/fs-constants/-/fs-constants-1.0.0.tgz", + "integrity": "sha512-y6OAwoSIf7FyjMIv94u+b5rdheZEjzR63GTyZJm5qh4Bi+2YgwLCcI/fPFZkL5PSixOt6ZNKm+w+Hfp/Bciwow==", + "dev": true + }, + "node_modules/fs.realpath": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/fs.realpath/-/fs.realpath-1.0.0.tgz", + "integrity": "sha512-OO0pH2lK6a0hZnAdau5ItzHPI6pUlvI7jMVnxUQRtw4owF2wk8lOSabtGDCTP4Ggrg2MbGnWO9X8K1t4+fGMDw==", + "dev": true + }, + "node_modules/function-bind": { + "version": "1.1.2", + "resolved": "https://registry.npmjs.org/function-bind/-/function-bind-1.1.2.tgz", + "integrity": "sha512-7XHNxH7qX9xG5mIwxkhumTox/MIRNcOgDrxWsMt2pAr23WHp6MrRlN7FBSFpCpr+oVO0F744iUgR82nJMfG2SA==", + "dev": true, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/function.prototype.name": { + "version": "1.1.6", + "resolved": "https://registry.npmjs.org/function.prototype.name/-/function.prototype.name-1.1.6.tgz", + "integrity": "sha512-Z5kx79swU5P27WEayXM1tBi5Ze/lbIyiNgU3qyXUOf9b2rgXYyF9Dy9Cx+IQv/Lc8WCG6L82zwUPpSS9hGehIg==", + "dev": true, + "dependencies": { + "call-bind": "^1.0.2", + "define-properties": "^1.2.0", + "es-abstract": "^1.22.1", + "functions-have-names": "^1.2.3" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/functions-have-names": { + "version": "1.2.3", + "resolved": "https://registry.npmjs.org/functions-have-names/-/functions-have-names-1.2.3.tgz", + "integrity": "sha512-xckBUXyTIqT97tq2x2AMb+g163b5JFysYk0x4qxNFwbfQkmNZoiRHb6sPzI9/QV33WeuvVYBUIiD4NzNIyqaRQ==", + "dev": true, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/gensync": { + "version": "1.0.0-beta.2", + "resolved": "https://registry.npmjs.org/gensync/-/gensync-1.0.0-beta.2.tgz", + "integrity": "sha512-3hN7NaskYvMDLQY55gnW3NQ+mesEAepTqlg+VEbj7zzqEMBVNhzcGYYeqFo/TlYz6eQiFcp1HcsCZO+nGgS8zg==", + "dev": true, + "engines": { + "node": ">=6.9.0" + } + }, + "node_modules/get-caller-file": { + "version": "2.0.5", + "resolved": "https://registry.npmjs.org/get-caller-file/-/get-caller-file-2.0.5.tgz", + "integrity": "sha512-DyFP3BM/3YHTQOCUL/w0OZHR0lpKeGrxotcHWcqNEdnltqFwXVfhEBQ94eIo34AfQpo0rGki4cyIiftY06h2Fg==", + "dev": true, + "engines": { + "node": "6.* || 8.* || >= 10.*" + } + }, + "node_modules/get-func-name": { + "version": "2.0.2", + "resolved": "https://registry.npmjs.org/get-func-name/-/get-func-name-2.0.2.tgz", + "integrity": "sha512-8vXOvuE167CtIc3OyItco7N/dpRtBbYOsPsXCz7X/PMnlGjYjSGuZJgM1Y7mmew7BKf9BqvLX2tnOVy1BBUsxQ==", + "dev": true, + "engines": { + "node": "*" + } + }, + "node_modules/get-intrinsic": { + "version": "1.2.4", + "resolved": "https://registry.npmjs.org/get-intrinsic/-/get-intrinsic-1.2.4.tgz", + "integrity": "sha512-5uYhsJH8VJBTv7oslg4BznJYhDoRI6waYCxMmCdnTrcCrHA/fCFKoTFz2JKKE0HdDFUF7/oQuhzumXJK7paBRQ==", + "dev": true, + "dependencies": { + "es-errors": "^1.3.0", + "function-bind": "^1.1.2", + "has-proto": "^1.0.1", + "has-symbols": "^1.0.3", + "hasown": "^2.0.0" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/get-package-type": { + "version": "0.1.0", + "resolved": "https://registry.npmjs.org/get-package-type/-/get-package-type-0.1.0.tgz", + "integrity": "sha512-pjzuKtY64GYfWizNAJ0fr9VqttZkNiK2iS430LtIHzjBEr6bX8Am2zm4sW4Ro5wjWW5cAlRL1qAMTcXbjNAO2Q==", + "dev": true, + "engines": { + "node": ">=8.0.0" + } + }, + "node_modules/get-stdin": { + "version": "8.0.0", + "resolved": "https://registry.npmjs.org/get-stdin/-/get-stdin-8.0.0.tgz", + "integrity": "sha512-sY22aA6xchAzprjyqmSEQv4UbAAzRN0L2dQB0NlN5acTTK9Don6nhoc3eAbUnpZiCANAMfd/+40kVdKfFygohg==", + "dev": true, + "engines": { + "node": ">=10" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/get-stream": { + "version": "5.2.0", + "resolved": "https://registry.npmjs.org/get-stream/-/get-stream-5.2.0.tgz", + "integrity": "sha512-nBF+F1rAZVCu/p7rjzgA+Yb4lfYXrpl7a6VmJrU8wF9I1CKvP/QwPNZHnOlwbTkY6dvtFIzFMSyQXbLoTQPRpA==", + "dev": true, + "dependencies": { + "pump": "^3.0.0" + }, + "engines": { + "node": ">=8" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/get-symbol-description": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/get-symbol-description/-/get-symbol-description-1.0.2.tgz", + "integrity": "sha512-g0QYk1dZBxGwk+Ngc+ltRH2IBp2f7zBkBMBJZCDerh6EhlhSR6+9irMCuT/09zD6qkarHUSn529sK/yL4S27mg==", + "dev": true, + "dependencies": { + "call-bind": "^1.0.5", + "es-errors": "^1.3.0", + "get-intrinsic": "^1.2.4" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/glob": { + "version": "7.2.3", + "resolved": "https://registry.npmjs.org/glob/-/glob-7.2.3.tgz", + "integrity": "sha512-nFR0zLpU2YCaRxwoCJvL6UvCH2JFyFVIvwTLsIf21AuHlMskA1hhTdk+LlYJtOlYt9v6dvszD2BGRqBL+iQK9Q==", + "deprecated": "Glob versions prior to v9 are no longer supported", + "dev": true, + "dependencies": { + "fs.realpath": "^1.0.0", + "inflight": "^1.0.4", + "inherits": "2", + "minimatch": "^3.1.1", + "once": "^1.3.0", + "path-is-absolute": "^1.0.0" + }, + "engines": { + "node": "*" + }, + "funding": { + "url": "https://github.com/sponsors/isaacs" + } + }, + "node_modules/glob-parent": { + "version": "6.0.2", + "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-6.0.2.tgz", + "integrity": "sha512-XxwI8EOhVQgWp6iDL+3b0r86f4d6AX6zSU55HfB4ydCEuXLXc5FcYeOu+nnGftS4TEju/11rt4KJPTMgbfmv4A==", + "dev": true, + "dependencies": { + "is-glob": "^4.0.3" + }, + "engines": { + "node": ">=10.13.0" + } + }, + "node_modules/globals": { + "version": "11.12.0", + "resolved": "https://registry.npmjs.org/globals/-/globals-11.12.0.tgz", + "integrity": "sha512-WOBp/EEGUiIsJSp7wcv/y6MO+lV9UoncWqxuFfm8eBwzWNgyfBd6Gz+IeKQ9jCmyhoH99g15M3T+QaVHFjizVA==", + "dev": true, + "engines": { + "node": ">=4" + } + }, + "node_modules/globalthis": { + "version": "1.0.4", + "resolved": "https://registry.npmjs.org/globalthis/-/globalthis-1.0.4.tgz", + "integrity": "sha512-DpLKbNU4WylpxJykQujfCcwYWiV/Jhm50Goo0wrVILAv5jOr9d+H+UR3PhSCD2rCCEIg0uc+G+muBTwD54JhDQ==", + "dev": true, + "dependencies": { + "define-properties": "^1.2.1", + "gopd": "^1.0.1" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/gopd": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/gopd/-/gopd-1.0.1.tgz", + "integrity": "sha512-d65bNlIadxvpb/A2abVdlqKqV563juRnZ1Wtk6s1sIR8uNsXR70xqIzVqxVf1eTqDunwT2MkczEeaezCKTZhwA==", + "dev": true, + "dependencies": { + "get-intrinsic": "^1.1.3" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/graceful-fs": { + "version": "4.2.11", + "resolved": "https://registry.npmjs.org/graceful-fs/-/graceful-fs-4.2.11.tgz", + "integrity": "sha512-RbJ5/jmFcNNCcDV5o9eTnBLJ/HszWV0P73bc+Ff4nS/rJj+YaS6IGyiOL0VoBYX+l1Wrl3k63h/KrH+nhJ0XvQ==", + "dev": true + }, + "node_modules/graphemer": { + "version": "1.4.0", + "resolved": "https://registry.npmjs.org/graphemer/-/graphemer-1.4.0.tgz", + "integrity": "sha512-EtKwoO6kxCL9WO5xipiHTZlSzBm7WLT627TqC/uVRd0HKmq8NXyebnNYxDoBi7wt8eTWrUrKXCOVaFq9x1kgag==", + "dev": true + }, + "node_modules/has-bigints": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/has-bigints/-/has-bigints-1.0.2.tgz", + "integrity": "sha512-tSvCKtBr9lkF0Ex0aQiP9N+OpV4zi2r/Nee5VkRDbaqv35RLYMzbwQfFSZZH0kR+Rd6302UJZ2p/bJCEoR3VoQ==", + "dev": true, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/has-flag": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-3.0.0.tgz", + "integrity": "sha512-sKJf1+ceQBr4SMkvQnBDNDtf4TXpVhVGateu0t918bl30FnbE2m4vNLX+VWe/dpjlb+HugGYzW7uQXH98HPEYw==", + "dev": true, + "engines": { + "node": ">=4" + } + }, + "node_modules/has-property-descriptors": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/has-property-descriptors/-/has-property-descriptors-1.0.2.tgz", + "integrity": "sha512-55JNKuIW+vq4Ke1BjOTjM2YctQIvCT7GFzHwmfZPGo5wnrgkid0YQtnAleFSqumZm4az3n2BS+erby5ipJdgrg==", + "dev": true, + "dependencies": { + "es-define-property": "^1.0.0" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/has-proto": { + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/has-proto/-/has-proto-1.0.3.tgz", + "integrity": "sha512-SJ1amZAJUiZS+PhsVLf5tGydlaVB8EdFpaSO4gmiUKUOxk8qzn5AIy4ZeJUmh22znIdk/uMAUT2pl3FxzVUH+Q==", + "dev": true, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/has-symbols": { + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/has-symbols/-/has-symbols-1.0.3.tgz", + "integrity": "sha512-l3LCuF6MgDNwTDKkdYGEihYjt5pRPbEg46rtlmnSPlUbgmB8LOIrKJbYYFBSbnPaJexMKtiPO8hmeRjRz2Td+A==", + "dev": true, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/has-tostringtag": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/has-tostringtag/-/has-tostringtag-1.0.2.tgz", + "integrity": "sha512-NqADB8VjPFLM2V0VvHUewwwsw0ZWBaIdgo+ieHtK3hasLz4qeCRjYcqfB6AQrBggRKppKF8L52/VqdVsO47Dlw==", + "dev": true, + "dependencies": { + "has-symbols": "^1.0.3" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/hasha": { + "version": "5.2.2", + "resolved": "https://registry.npmjs.org/hasha/-/hasha-5.2.2.tgz", + "integrity": "sha512-Hrp5vIK/xr5SkeN2onO32H0MgNZ0f17HRNH39WfL0SYUNOTZ5Lz1TJ8Pajo/87dYGEFlLMm7mIc/k/s6Bvz9HQ==", + "dev": true, + "dependencies": { + "is-stream": "^2.0.0", + "type-fest": "^0.8.0" + }, + "engines": { + "node": ">=8" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/hasown": { + "version": "2.0.2", + "resolved": "https://registry.npmjs.org/hasown/-/hasown-2.0.2.tgz", + "integrity": "sha512-0hJU9SCPvmMzIBdZFqNPXWa6dqh7WdH0cII9y+CyS8rG3nL48Bclra9HmKhVVUHyPWNH5Y7xDwAB7bfgSjkUMQ==", + "dev": true, + "dependencies": { + "function-bind": "^1.1.2" + }, + "engines": { + "node": ">= 0.4" + } + }, + "node_modules/html-escaper": { + "version": "2.0.2", + "resolved": "https://registry.npmjs.org/html-escaper/-/html-escaper-2.0.2.tgz", + "integrity": "sha512-H2iMtd0I4Mt5eYiapRdIDjp+XzelXQ0tFE4JS7YFwFevXXMmOp9myNrUvCg0D6ws8iqkRPBfKHgbwig1SmlLfg==", + "dev": true + }, + "node_modules/https-proxy-agent": { + "version": "5.0.1", + "resolved": "https://registry.npmjs.org/https-proxy-agent/-/https-proxy-agent-5.0.1.tgz", + "integrity": "sha512-dFcAjpTQFgoLMzC2VwU+C/CbS7uRL0lWmxDITmqm7C+7F0Odmj6s9l6alZc6AELXhrnggM2CeWSXHGOdX2YtwA==", + "dev": true, + "dependencies": { + "agent-base": "6", + "debug": "4" + }, + "engines": { + "node": ">= 6" + } + }, + "node_modules/ieee754": { + "version": "1.2.1", + "resolved": "https://registry.npmjs.org/ieee754/-/ieee754-1.2.1.tgz", + "integrity": "sha512-dcyqhDvX1C46lXZcVqCpK+FtMRQVdIMN6/Df5js2zouUsqG7I6sFxitIC+7KYK29KdXOLHdu9zL4sFnoVQnqaA==", + "dev": true, + "funding": [ + { + "type": "github", + "url": "https://github.com/sponsors/feross" + }, + { + "type": "patreon", + "url": "https://www.patreon.com/feross" + }, + { + "type": "consulting", + "url": "https://feross.org/support" + } + ] + }, + "node_modules/ignore": { + "version": "5.3.2", + "resolved": "https://registry.npmjs.org/ignore/-/ignore-5.3.2.tgz", + "integrity": "sha512-hsBTNUqQTDwkWtcdYI2i06Y/nUBEsNEDJKjWdigLvegy8kDuJAS8uRlpkkcQpyEXL0Z/pjDy5HBmMjRCJ2gq+g==", + "dev": true, + "engines": { + "node": ">= 4" + } + }, + "node_modules/import-fresh": { + "version": "3.3.0", + "resolved": "https://registry.npmjs.org/import-fresh/-/import-fresh-3.3.0.tgz", + "integrity": "sha512-veYYhQa+D1QBKznvhUHxb8faxlrwUnxseDAbAp457E0wLNio2bOSKnjYDhMj+YiAq61xrMGhQk9iXVk5FzgQMw==", + "dev": true, + "dependencies": { + "parent-module": "^1.0.0", + "resolve-from": "^4.0.0" + }, + "engines": { + "node": ">=6" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/import-fresh/node_modules/resolve-from": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/resolve-from/-/resolve-from-4.0.0.tgz", + "integrity": "sha512-pb/MYmXstAkysRFx8piNI1tGFNQIFA3vkE3Gq4EuA1dF6gHp/+vgZqsCGJapvy8N3Q+4o7FwvquPJcnZ7RYy4g==", + "dev": true, + "engines": { + "node": ">=4" + } + }, + "node_modules/imurmurhash": { + "version": "0.1.4", + "resolved": "https://registry.npmjs.org/imurmurhash/-/imurmurhash-0.1.4.tgz", + "integrity": "sha512-JmXMZ6wuvDmLiHEml9ykzqO6lwFbof0GG4IkcGaENdCRDDmMVnny7s5HsIgHCbaq0w2MyPhDqkhTUgS2LU2PHA==", + "dev": true, + "engines": { + "node": ">=0.8.19" + } + }, + "node_modules/indent-string": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/indent-string/-/indent-string-4.0.0.tgz", + "integrity": "sha512-EdDDZu4A2OyIK7Lr/2zG+w5jmbuk1DVBnEwREQvBzspBJkCEbRa8GxU1lghYcaGJCnRWibjDXlq779X1/y5xwg==", + "dev": true, + "engines": { + "node": ">=8" + } + }, + "node_modules/inflight": { + "version": "1.0.6", + "resolved": "https://registry.npmjs.org/inflight/-/inflight-1.0.6.tgz", + "integrity": "sha512-k92I/b08q4wvFscXCLvqfsHCrjrF7yiXsQuIVvVE7N82W3+aqpzuUdBbfhWcy/FZR3/4IgflMgKLOsvPDrGCJA==", + "deprecated": "This module is not supported, and leaks memory. Do not use it. Check out lru-cache if you want a good and tested way to coalesce async requests by a key value, which is much more comprehensive and powerful.", + "dev": true, + "dependencies": { + "once": "^1.3.0", + "wrappy": "1" + } + }, + "node_modules/inherits": { + "version": "2.0.4", + "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.4.tgz", + "integrity": "sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ==", + "dev": true + }, + "node_modules/internal-slot": { + "version": "1.0.7", + "resolved": "https://registry.npmjs.org/internal-slot/-/internal-slot-1.0.7.tgz", + "integrity": "sha512-NGnrKwXzSms2qUUih/ILZ5JBqNTSa1+ZmP6flaIp6KmSElgE9qdndzS3cqjrDovwFdmwsGsLdeFgB6suw+1e9g==", + "dev": true, + "dependencies": { + "es-errors": "^1.3.0", + "hasown": "^2.0.0", + "side-channel": "^1.0.4" + }, + "engines": { + "node": ">= 0.4" + } + }, + "node_modules/is-array-buffer": { + "version": "3.0.4", + "resolved": "https://registry.npmjs.org/is-array-buffer/-/is-array-buffer-3.0.4.tgz", + "integrity": "sha512-wcjaerHw0ydZwfhiKbXJWLDY8A7yV7KhjQOpb83hGgGfId/aQa4TOvwyzn2PuswW2gPCYEL/nEAiSVpdOj1lXw==", + "dev": true, + "dependencies": { + "call-bind": "^1.0.2", + "get-intrinsic": "^1.2.1" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/is-arrayish": { + "version": "0.2.1", + "resolved": "https://registry.npmjs.org/is-arrayish/-/is-arrayish-0.2.1.tgz", + "integrity": "sha512-zz06S8t0ozoDXMG+ube26zeCTNXcKIPJZJi8hBrF4idCLms4CG9QtK7qBl1boi5ODzFpjswb5JPmHCbMpjaYzg==", + "dev": true + }, + "node_modules/is-async-function": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/is-async-function/-/is-async-function-2.0.0.tgz", + "integrity": "sha512-Y1JXKrfykRJGdlDwdKlLpLyMIiWqWvuSd17TvZk68PLAOGOoF4Xyav1z0Xhoi+gCYjZVeC5SI+hYFOfvXmGRCA==", + "dev": true, + "dependencies": { + "has-tostringtag": "^1.0.0" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/is-bigint": { + "version": "1.0.4", + "resolved": "https://registry.npmjs.org/is-bigint/-/is-bigint-1.0.4.tgz", + "integrity": "sha512-zB9CruMamjym81i2JZ3UMn54PKGsQzsJeo6xvN3HJJ4CAsQNB6iRutp2To77OfCNuoxspsIhzaPoO1zyCEhFOg==", + "dev": true, + "dependencies": { + "has-bigints": "^1.0.1" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/is-boolean-object": { + "version": "1.1.2", + "resolved": "https://registry.npmjs.org/is-boolean-object/-/is-boolean-object-1.1.2.tgz", + "integrity": "sha512-gDYaKHJmnj4aWxyj6YHyXVpdQawtVLHU5cb+eztPGczf6cjuTdwve5ZIEfgXqH4e57An1D1AKf8CZ3kYrQRqYA==", + "dev": true, + "dependencies": { + "call-bind": "^1.0.2", + "has-tostringtag": "^1.0.0" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/is-callable": { + "version": "1.2.7", + "resolved": "https://registry.npmjs.org/is-callable/-/is-callable-1.2.7.tgz", + "integrity": "sha512-1BC0BVFhS/p0qtw6enp8e+8OD0UrK0oFLztSjNzhcKA3WDuJxxAPXzPuPtKkjEY9UUoEWlX/8fgKeu2S8i9JTA==", + "dev": true, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/is-core-module": { + "version": "2.15.1", + "resolved": "https://registry.npmjs.org/is-core-module/-/is-core-module-2.15.1.tgz", + "integrity": "sha512-z0vtXSwucUJtANQWldhbtbt7BnL0vxiFjIdDLAatwhDYty2bad6s+rijD6Ri4YuYJubLzIJLUidCh09e1djEVQ==", + "dev": true, + "dependencies": { + "hasown": "^2.0.2" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/is-data-view": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/is-data-view/-/is-data-view-1.0.1.tgz", + "integrity": "sha512-AHkaJrsUVW6wq6JS8y3JnM/GJF/9cf+k20+iDzlSaJrinEo5+7vRiteOSwBhHRiAyQATN1AmY4hwzxJKPmYf+w==", + "dev": true, + "dependencies": { + "is-typed-array": "^1.1.13" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/is-date-object": { + "version": "1.0.5", + "resolved": "https://registry.npmjs.org/is-date-object/-/is-date-object-1.0.5.tgz", + "integrity": "sha512-9YQaSxsAiSwcvS33MBk3wTCVnWK+HhF8VZR2jRxehM16QcVOdHqPn4VPHmRK4lSr38n9JriurInLcP90xsYNfQ==", + "dev": true, + "dependencies": { + "has-tostringtag": "^1.0.0" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/is-extglob": { + "version": "2.1.1", + "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz", + "integrity": "sha512-SbKbANkN603Vi4jEZv49LeVJMn4yGwsbzZworEoyEiutsN3nJYdbO36zfhGJ6QEDpOZIFkDtnq5JRxmvl3jsoQ==", + "dev": true, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/is-finalizationregistry": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/is-finalizationregistry/-/is-finalizationregistry-1.0.2.tgz", + "integrity": "sha512-0by5vtUJs8iFQb5TYUHHPudOR+qXYIMKtiUzvLIZITZUjknFmziyBJuLhVRc+Ds0dREFlskDNJKYIdIzu/9pfw==", + "dev": true, + "dependencies": { + "call-bind": "^1.0.2" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/is-fullwidth-code-point": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-3.0.0.tgz", + "integrity": "sha512-zymm5+u+sCsSWyD9qNaejV3DFvhCKclKdizYaJUuHA83RLjb7nSuGnddCHGv0hk+KY7BMAlsWeK4Ueg6EV6XQg==", + "dev": true, + "engines": { + "node": ">=8" + } + }, + "node_modules/is-generator-function": { + "version": "1.0.10", + "resolved": "https://registry.npmjs.org/is-generator-function/-/is-generator-function-1.0.10.tgz", + "integrity": "sha512-jsEjy9l3yiXEQ+PsXdmBwEPcOxaXWLspKdplFUVI9vq1iZgIekeC0L167qeu86czQaxed3q/Uzuw0swL0irL8A==", + "dev": true, + "dependencies": { + "has-tostringtag": "^1.0.0" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/is-glob": { + "version": "4.0.3", + "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-4.0.3.tgz", + "integrity": "sha512-xelSayHH36ZgE7ZWhli7pW34hNbNl8Ojv5KVmkJD4hBdD3th8Tfk9vYasLM+mXWOZhFkgZfxhLSnrwRr4elSSg==", + "dev": true, + "dependencies": { + "is-extglob": "^2.1.1" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/is-map": { + "version": "2.0.3", + "resolved": "https://registry.npmjs.org/is-map/-/is-map-2.0.3.tgz", + "integrity": "sha512-1Qed0/Hr2m+YqxnM09CjA2d/i6YZNfF6R2oRAOj36eUdS6qIV/huPJNSEpKbupewFs+ZsJlxsjjPbc0/afW6Lw==", + "dev": true, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/is-negative-zero": { + "version": "2.0.3", + "resolved": "https://registry.npmjs.org/is-negative-zero/-/is-negative-zero-2.0.3.tgz", + "integrity": "sha512-5KoIu2Ngpyek75jXodFvnafB6DJgr3u8uuK0LEZJjrU19DrMD3EVERaR8sjz8CCGgpZvxPl9SuE1GMVPFHx1mw==", + "dev": true, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/is-number-object": { + "version": "1.0.7", + "resolved": "https://registry.npmjs.org/is-number-object/-/is-number-object-1.0.7.tgz", + "integrity": "sha512-k1U0IRzLMo7ZlYIfzRu23Oh6MiIFasgpb9X76eqfFZAqwH44UI4KTBvBYIZ1dSL9ZzChTB9ShHfLkR4pdW5krQ==", + "dev": true, + "dependencies": { + "has-tostringtag": "^1.0.0" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/is-path-inside": { + "version": "3.0.3", + "resolved": "https://registry.npmjs.org/is-path-inside/-/is-path-inside-3.0.3.tgz", + "integrity": "sha512-Fd4gABb+ycGAmKou8eMftCupSir5lRxqf4aD/vd0cD2qc4HL07OjCeuHMr8Ro4CoMaeCKDB0/ECBOVWjTwUvPQ==", + "dev": true, + "engines": { + "node": ">=8" + } + }, + "node_modules/is-regex": { + "version": "1.1.4", + "resolved": "https://registry.npmjs.org/is-regex/-/is-regex-1.1.4.tgz", + "integrity": "sha512-kvRdxDsxZjhzUX07ZnLydzS1TU/TJlTUHHY4YLL87e37oUA49DfkLqgy+VjFocowy29cKvcSiu+kIv728jTTVg==", + "dev": true, + "dependencies": { + "call-bind": "^1.0.2", + "has-tostringtag": "^1.0.0" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/is-set": { + "version": "2.0.3", + "resolved": "https://registry.npmjs.org/is-set/-/is-set-2.0.3.tgz", + "integrity": "sha512-iPAjerrse27/ygGLxw+EBR9agv9Y6uLeYVJMu+QNCoouJ1/1ri0mGrcWpfCqFZuzzx3WjtwxG098X+n4OuRkPg==", + "dev": true, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/is-shared-array-buffer": { + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/is-shared-array-buffer/-/is-shared-array-buffer-1.0.3.tgz", + "integrity": "sha512-nA2hv5XIhLR3uVzDDfCIknerhx8XUKnstuOERPNNIinXG7v9u+ohXF67vxm4TPTEPU6lm61ZkwP3c9PCB97rhg==", + "dev": true, + "dependencies": { + "call-bind": "^1.0.7" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/is-stream": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/is-stream/-/is-stream-2.0.1.tgz", + "integrity": "sha512-hFoiJiTl63nn+kstHGBtewWSKnQLpyb155KHheA1l39uvtO9nWIop1p3udqPcUd/xbF1VLMO4n7OI6p7RbngDg==", + "dev": true, + "engines": { + "node": ">=8" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/is-string": { + "version": "1.0.7", + "resolved": "https://registry.npmjs.org/is-string/-/is-string-1.0.7.tgz", + "integrity": "sha512-tE2UXzivje6ofPW7l23cjDOMa09gb7xlAqG6jG5ej6uPV32TlWP3NKPigtaGeHNu9fohccRYvIiZMfOOnOYUtg==", + "dev": true, + "dependencies": { + "has-tostringtag": "^1.0.0" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/is-symbol": { + "version": "1.0.4", + "resolved": "https://registry.npmjs.org/is-symbol/-/is-symbol-1.0.4.tgz", + "integrity": "sha512-C/CPBqKWnvdcxqIARxyOh4v1UUEOCHpgDa0WYgpKDFMszcrPcffg5uhwSgPCLD2WWxmq6isisz87tzT01tuGhg==", + "dev": true, + "dependencies": { + "has-symbols": "^1.0.2" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/is-typed-array": { + "version": "1.1.13", + "resolved": "https://registry.npmjs.org/is-typed-array/-/is-typed-array-1.1.13.tgz", + "integrity": "sha512-uZ25/bUAlUY5fR4OKT4rZQEBrzQWYV9ZJYGGsUmEJ6thodVJ1HX64ePQ6Z0qPWP+m+Uq6e9UugrE38jeYsDSMw==", + "dev": true, + "dependencies": { + "which-typed-array": "^1.1.14" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/is-typedarray": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/is-typedarray/-/is-typedarray-1.0.0.tgz", + "integrity": "sha512-cyA56iCMHAh5CdzjJIa4aohJyeO1YbwLi3Jc35MmRU6poroFjIGZzUzupGiRPOjgHg9TLu43xbpwXk523fMxKA==", + "dev": true + }, + "node_modules/is-weakmap": { + "version": "2.0.2", + "resolved": "https://registry.npmjs.org/is-weakmap/-/is-weakmap-2.0.2.tgz", + "integrity": "sha512-K5pXYOm9wqY1RgjpL3YTkF39tni1XajUIkawTLUo9EZEVUFga5gSQJF8nNS7ZwJQ02y+1YCNYcMh+HIf1ZqE+w==", + "dev": true, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/is-weakref": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/is-weakref/-/is-weakref-1.0.2.tgz", + "integrity": "sha512-qctsuLZmIQ0+vSSMfoVvyFe2+GSEvnmZ2ezTup1SBse9+twCCeial6EEi3Nc2KFcf6+qz2FBPnjXsk8xhKSaPQ==", + "dev": true, + "dependencies": { + "call-bind": "^1.0.2" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/is-weakset": { + "version": "2.0.3", + "resolved": "https://registry.npmjs.org/is-weakset/-/is-weakset-2.0.3.tgz", + "integrity": "sha512-LvIm3/KWzS9oRFHugab7d+M/GcBXuXX5xZkzPmN+NxihdQlZUQ4dWuSV1xR/sq6upL1TJEDrfBgRepHFdBtSNQ==", + "dev": true, + "dependencies": { + "call-bind": "^1.0.7", + "get-intrinsic": "^1.2.4" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/is-windows": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/is-windows/-/is-windows-1.0.2.tgz", + "integrity": "sha512-eXK1UInq2bPmjyX6e3VHIzMLobc4J94i4AWn+Hpq3OU5KkrRC96OAcR3PRJ/pGu6m8TRnBHP9dkXQVsT/COVIA==", + "dev": true, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/isarray": { + "version": "2.0.5", + "resolved": "https://registry.npmjs.org/isarray/-/isarray-2.0.5.tgz", + "integrity": "sha512-xHjhDr3cNBK0BzdUJSPXZntQUx/mwMS5Rw4A7lPJ90XGAO6ISP/ePDNuo0vhqOZU+UD5JoodwCAAoZQd3FeAKw==", + "dev": true + }, + "node_modules/isexe": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/isexe/-/isexe-2.0.0.tgz", + "integrity": "sha512-RHxMLp9lnKHGHRng9QFhRCMbYAcVpn69smSGcq3f36xjgVVWThj4qqLbTLlq7Ssj8B+fIQ1EuCEGI2lKsyQeIw==", + "dev": true + }, + "node_modules/istanbul-lib-coverage": { + "version": "3.2.2", + "resolved": "https://registry.npmjs.org/istanbul-lib-coverage/-/istanbul-lib-coverage-3.2.2.tgz", + "integrity": "sha512-O8dpsF+r0WV/8MNRKfnmrtCWhuKjxrq2w+jpzBL5UZKTi2LeVWnWOmWRxFlesJONmc+wLAGvKQZEOanko0LFTg==", + "dev": true, + "engines": { + "node": ">=8" + } + }, + "node_modules/istanbul-lib-hook": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/istanbul-lib-hook/-/istanbul-lib-hook-3.0.0.tgz", + "integrity": "sha512-Pt/uge1Q9s+5VAZ+pCo16TYMWPBIl+oaNIjgLQxcX0itS6ueeaA+pEfThZpH8WxhFgCiEb8sAJY6MdUKgiIWaQ==", + "dev": true, + "dependencies": { + "append-transform": "^2.0.0" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/istanbul-lib-instrument": { + "version": "5.2.1", + "resolved": "https://registry.npmjs.org/istanbul-lib-instrument/-/istanbul-lib-instrument-5.2.1.tgz", + "integrity": "sha512-pzqtp31nLv/XFOzXGuvhCb8qhjmTVo5vjVk19XE4CRlSWz0KoeJ3bw9XsA7nOp9YBf4qHjwBxkDzKcME/J29Yg==", + "dev": true, + "dependencies": { + "@babel/core": "^7.12.3", + "@babel/parser": "^7.14.7", + "@istanbuljs/schema": "^0.1.2", + "istanbul-lib-coverage": "^3.2.0", + "semver": "^6.3.0" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/istanbul-lib-processinfo": { + "version": "2.0.3", + "resolved": "https://registry.npmjs.org/istanbul-lib-processinfo/-/istanbul-lib-processinfo-2.0.3.tgz", + "integrity": "sha512-NkwHbo3E00oybX6NGJi6ar0B29vxyvNwoC7eJ4G4Yq28UfY758Hgn/heV8VRFhevPED4LXfFz0DQ8z/0kw9zMg==", + "dev": true, + "dependencies": { + "archy": "^1.0.0", + "cross-spawn": "^7.0.3", + "istanbul-lib-coverage": "^3.2.0", + "p-map": "^3.0.0", + "rimraf": "^3.0.0", + "uuid": "^8.3.2" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/istanbul-lib-report": { + "version": "3.0.1", + "resolved": "https://registry.npmjs.org/istanbul-lib-report/-/istanbul-lib-report-3.0.1.tgz", + "integrity": "sha512-GCfE1mtsHGOELCU8e/Z7YWzpmybrx/+dSTfLrvY8qRmaY6zXTKWn6WQIjaAFw069icm6GVMNkgu0NzI4iPZUNw==", + "dev": true, + "dependencies": { + "istanbul-lib-coverage": "^3.0.0", + "make-dir": "^4.0.0", + "supports-color": "^7.1.0" + }, + "engines": { + "node": ">=10" + } + }, + "node_modules/istanbul-lib-report/node_modules/has-flag": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", + "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==", + "dev": true, + "engines": { + "node": ">=8" + } + }, + "node_modules/istanbul-lib-report/node_modules/make-dir": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/make-dir/-/make-dir-4.0.0.tgz", + "integrity": "sha512-hXdUTZYIVOt1Ex//jAQi+wTZZpUpwBj/0QsOzqegb3rGMMeJiSEu5xLHnYfBrRV4RH2+OCSOO95Is/7x1WJ4bw==", + "dev": true, + "dependencies": { + "semver": "^7.5.3" + }, + "engines": { + "node": ">=10" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/istanbul-lib-report/node_modules/semver": { + "version": "7.6.3", + "resolved": "https://registry.npmjs.org/semver/-/semver-7.6.3.tgz", + "integrity": "sha512-oVekP1cKtI+CTDvHWYFUcMtsK/00wmAEfyqKfNdARm8u1wNVhSgaX7A8d4UuIlUI5e84iEwOhs7ZPYRmzU9U6A==", + "dev": true, + "bin": { + "semver": "bin/semver.js" + }, + "engines": { + "node": ">=10" + } + }, + "node_modules/istanbul-lib-report/node_modules/supports-color": { + "version": "7.2.0", + "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz", + "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==", + "dev": true, + "dependencies": { + "has-flag": "^4.0.0" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/istanbul-lib-source-maps": { + "version": "4.0.1", + "resolved": "https://registry.npmjs.org/istanbul-lib-source-maps/-/istanbul-lib-source-maps-4.0.1.tgz", + "integrity": "sha512-n3s8EwkdFIJCG3BPKBYvskgXGoy88ARzvegkitk60NxRdwltLOTaH7CUiMRXvwYorl0Q712iEjcWB+fK/MrWVw==", + "dev": true, + "dependencies": { + "debug": "^4.1.1", + "istanbul-lib-coverage": "^3.0.0", + "source-map": "^0.6.1" + }, + "engines": { + "node": ">=10" + } + }, + "node_modules/istanbul-reports": { + "version": "3.1.7", + "resolved": "https://registry.npmjs.org/istanbul-reports/-/istanbul-reports-3.1.7.tgz", + "integrity": "sha512-BewmUXImeuRk2YY0PVbxgKAysvhRPUQE0h5QRM++nVWyubKGV0l8qQ5op8+B2DOmwSe63Jivj0BjkPQVf8fP5g==", + "dev": true, + "dependencies": { + "html-escaper": "^2.0.0", + "istanbul-lib-report": "^3.0.0" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/iterator.prototype": { + "version": "1.1.2", + "resolved": "https://registry.npmjs.org/iterator.prototype/-/iterator.prototype-1.1.2.tgz", + "integrity": "sha512-DR33HMMr8EzwuRL8Y9D3u2BMj8+RqSE850jfGu59kS7tbmPLzGkZmVSfyCFSDxuZiEY6Rzt3T2NA/qU+NwVj1w==", + "dev": true, + "dependencies": { + "define-properties": "^1.2.1", + "get-intrinsic": "^1.2.1", + "has-symbols": "^1.0.3", + "reflect.getprototypeof": "^1.0.4", + "set-function-name": "^2.0.1" + } + }, + "node_modules/js-tokens": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/js-tokens/-/js-tokens-4.0.0.tgz", + "integrity": "sha512-RdJUflcE3cUzKiMqQgsCu06FPu9UdIJO0beYbPhHN4k6apgJtifcoCtT9bcxOpYBtpD2kCM6Sbzg4CausW/PKQ==", + "dev": true + }, + "node_modules/js-yaml": { + "version": "3.14.1", + "resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-3.14.1.tgz", + "integrity": "sha512-okMH7OXXJ7YrN9Ok3/SXrnu4iX9yOk+25nqX4imS2npuvTYDmo/QEZoqwZkYaIDk3jVvBOTOIEgEhaLOynBS9g==", + "dev": true, + "dependencies": { + "argparse": "^1.0.7", + "esprima": "^4.0.0" + }, + "bin": { + "js-yaml": "bin/js-yaml.js" + } + }, + "node_modules/jsesc": { + "version": "2.5.2", + "resolved": "https://registry.npmjs.org/jsesc/-/jsesc-2.5.2.tgz", + "integrity": "sha512-OYu7XEzjkCQ3C5Ps3QIZsQfNpqoJyZZA99wd9aWd05NCtC5pWOkShK2mkL6HXQR6/Cy2lbNdPlZBpuQHXE63gA==", + "dev": true, + "bin": { + "jsesc": "bin/jsesc" + }, + "engines": { + "node": ">=4" + } + }, + "node_modules/json-buffer": { + "version": "3.0.1", + "resolved": "https://registry.npmjs.org/json-buffer/-/json-buffer-3.0.1.tgz", + "integrity": "sha512-4bV5BfR2mqfQTJm+V5tPPdf+ZpuhiIvTuAB5g8kcrXOZpTT/QwwVRWBywX1ozr6lEuPdbHxwaJlm9G6mI2sfSQ==", + "dev": true + }, + "node_modules/json-parse-better-errors": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/json-parse-better-errors/-/json-parse-better-errors-1.0.2.tgz", + "integrity": "sha512-mrqyZKfX5EhL7hvqcV6WG1yYjnjeuYDzDhhcAAUrq8Po85NBQBJP+ZDUT75qZQ98IkUoBqdkExkukOU7Ts2wrw==", + "dev": true + }, + "node_modules/json-parse-even-better-errors": { + "version": "2.3.1", + "resolved": "https://registry.npmjs.org/json-parse-even-better-errors/-/json-parse-even-better-errors-2.3.1.tgz", + "integrity": "sha512-xyFwyhro/JEof6Ghe2iz2NcXoj2sloNsWr/XsERDK/oiPCfaNhl5ONfp+jQdAZRQQ0IJWNzH9zIZF7li91kh2w==", + "dev": true + }, + "node_modules/json-schema-traverse": { + "version": "0.4.1", + "resolved": "https://registry.npmjs.org/json-schema-traverse/-/json-schema-traverse-0.4.1.tgz", + "integrity": "sha512-xbbCH5dCYU5T8LcEhhuh7HJ88HXuW3qsI3Y0zOZFKfZEHcpWiHU/Jxzk629Brsab/mMiHQti9wMP+845RPe3Vg==", + "dev": true + }, + "node_modules/json-stable-stringify-without-jsonify": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/json-stable-stringify-without-jsonify/-/json-stable-stringify-without-jsonify-1.0.1.tgz", + "integrity": "sha512-Bdboy+l7tA3OGW6FjyFHWkP5LuByj1Tk33Ljyq0axyzdk9//JSi2u3fP1QSmd1KNwq6VOKYGlAu87CisVir6Pw==", + "dev": true + }, + "node_modules/json5": { + "version": "2.2.3", + "resolved": "https://registry.npmjs.org/json5/-/json5-2.2.3.tgz", + "integrity": "sha512-XmOWe7eyHYH14cLdVPoyg+GOH3rYX++KpzrylJwSW98t3Nk+U8XOl8FWKOgwtzdb8lXGf6zYwDUzeHMWfxasyg==", + "dev": true, + "bin": { + "json5": "lib/cli.js" + }, + "engines": { + "node": ">=6" + } + }, + "node_modules/jsx-ast-utils": { + "version": "3.3.5", + "resolved": "https://registry.npmjs.org/jsx-ast-utils/-/jsx-ast-utils-3.3.5.tgz", + "integrity": "sha512-ZZow9HBI5O6EPgSJLUb8n2NKgmVWTwCvHGwFuJlMjvLFqlGG6pjirPhtdsseaLZjSibD8eegzmYpUZwoIlj2cQ==", + "dev": true, + "dependencies": { + "array-includes": "^3.1.6", + "array.prototype.flat": "^1.3.1", + "object.assign": "^4.1.4", + "object.values": "^1.1.6" + }, + "engines": { + "node": ">=4.0" + } + }, + "node_modules/keyv": { + "version": "4.5.4", + "resolved": "https://registry.npmjs.org/keyv/-/keyv-4.5.4.tgz", + "integrity": "sha512-oxVHkHR/EJf2CNXnWxRLW6mg7JyCCUcG0DtEGmL2ctUo1PNTin1PUil+r/+4r5MpVgC/fn1kjsx7mjSujKqIpw==", + "dev": true, + "dependencies": { + "json-buffer": "3.0.1" + } + }, + "node_modules/levn": { + "version": "0.4.1", + "resolved": "https://registry.npmjs.org/levn/-/levn-0.4.1.tgz", + "integrity": "sha512-+bT2uH4E5LGE7h/n3evcS/sQlJXCpIp6ym8OWJ5eV6+67Dsql/LaaT7qJBAt2rzfoa/5QBGBhxDix1dMt2kQKQ==", + "dev": true, + "dependencies": { + "prelude-ls": "^1.2.1", + "type-check": "~0.4.0" + }, + "engines": { + "node": ">= 0.8.0" + } + }, + "node_modules/lines-and-columns": { + "version": "1.2.4", + "resolved": "https://registry.npmjs.org/lines-and-columns/-/lines-and-columns-1.2.4.tgz", + "integrity": "sha512-7ylylesZQ/PV29jhEDl3Ufjo6ZX7gCqJr5F7PKrqc93v7fzSymt1BpwEU8nAUXs8qzzvqhbjhK5QZg6Mt/HkBg==", + "dev": true + }, + "node_modules/load-json-file": { + "version": "5.3.0", + "resolved": "https://registry.npmjs.org/load-json-file/-/load-json-file-5.3.0.tgz", + "integrity": "sha512-cJGP40Jc/VXUsp8/OrnyKyTZ1y6v/dphm3bioS+RrKXjK2BB6wHUd6JptZEFDGgGahMT+InnZO5i1Ei9mpC8Bw==", + "dev": true, + "dependencies": { + "graceful-fs": "^4.1.15", + "parse-json": "^4.0.0", + "pify": "^4.0.1", + "strip-bom": "^3.0.0", + "type-fest": "^0.3.0" + }, + "engines": { + "node": ">=6" + } + }, + "node_modules/load-json-file/node_modules/parse-json": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/parse-json/-/parse-json-4.0.0.tgz", + "integrity": "sha512-aOIos8bujGN93/8Ox/jPLh7RwVnPEysynVFE+fQZyg6jKELEHwzgKdLRFHUgXJL6kylijVSBC4BvN9OmsB48Rw==", + "dev": true, + "dependencies": { + "error-ex": "^1.3.1", + "json-parse-better-errors": "^1.0.1" + }, + "engines": { + "node": ">=4" + } + }, + "node_modules/load-json-file/node_modules/strip-bom": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/strip-bom/-/strip-bom-3.0.0.tgz", + "integrity": "sha512-vavAMRXOgBVNF6nyEEmL3DBK19iRpDcoIwW+swQ+CbGiu7lju6t+JklA1MHweoWtadgt4ISVUsXLyDq34ddcwA==", + "dev": true, + "engines": { + "node": ">=4" + } + }, + "node_modules/load-json-file/node_modules/type-fest": { + "version": "0.3.1", + "resolved": "https://registry.npmjs.org/type-fest/-/type-fest-0.3.1.tgz", + "integrity": "sha512-cUGJnCdr4STbePCgqNFbpVNCepa+kAVohJs1sLhxzdH+gnEoOd8VhbYa7pD3zZYGiURWM2xzEII3fQcRizDkYQ==", + "dev": true, + "engines": { + "node": ">=6" + } + }, + "node_modules/locate-path": { + "version": "5.0.0", + "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-5.0.0.tgz", + "integrity": "sha512-t7hw9pI+WvuwNJXwk5zVHpyhIqzg2qTlklJOf0mVxGSbe3Fp2VieZcduNYjaLDoy6p9uGpQEGWG87WpMKlNq8g==", + "dev": true, + "dependencies": { + "p-locate": "^4.1.0" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/lodash.flattendeep": { + "version": "4.4.0", + "resolved": "https://registry.npmjs.org/lodash.flattendeep/-/lodash.flattendeep-4.4.0.tgz", + "integrity": "sha512-uHaJFihxmJcEX3kT4I23ABqKKalJ/zDrDg0lsFtc1h+3uw49SIJ5beyhx5ExVRti3AvKoOJngIj7xz3oylPdWQ==", + "dev": true + }, + "node_modules/lodash.merge": { + "version": "4.6.2", + "resolved": "https://registry.npmjs.org/lodash.merge/-/lodash.merge-4.6.2.tgz", + "integrity": "sha512-0KpjqXRVvrYyCsX1swR/XTK0va6VQkQM6MNo7PqW77ByjAhoARA8EfrP1N4+KlKj8YS0ZUCtRT/YUuhyYDujIQ==", + "dev": true + }, + "node_modules/loose-envify": { + "version": "1.4.0", + "resolved": "https://registry.npmjs.org/loose-envify/-/loose-envify-1.4.0.tgz", + "integrity": "sha512-lyuxPGr/Wfhrlem2CL/UcnUc1zcqKAImBDzukY7Y5F/yQiNdko6+fRLevlw1HgMySw7f611UIY408EtxRSoK3Q==", + "dev": true, + "dependencies": { + "js-tokens": "^3.0.0 || ^4.0.0" + }, + "bin": { + "loose-envify": "cli.js" + } + }, + "node_modules/loupe": { + "version": "2.3.7", + "resolved": "https://registry.npmjs.org/loupe/-/loupe-2.3.7.tgz", + "integrity": "sha512-zSMINGVYkdpYSOBmLi0D1Uo7JU9nVdQKrHxC8eYlV+9YKK9WePqAlL7lSlorG/U2Fw1w0hTBmaa/jrQ3UbPHtA==", + "dev": true, + "dependencies": { + "get-func-name": "^2.0.1" + } + }, + "node_modules/lru-cache": { + "version": "5.1.1", + "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-5.1.1.tgz", + "integrity": "sha512-KpNARQA3Iwv+jTA0utUVVbrh+Jlrr1Fv0e56GGzAFOXN7dk/FviaDW8LHmK52DlcH4WP2n6gI8vN1aesBFgo9w==", + "dev": true, + "dependencies": { + "yallist": "^3.0.2" + } + }, + "node_modules/make-dir": { + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/make-dir/-/make-dir-3.1.0.tgz", + "integrity": "sha512-g3FeP20LNwhALb/6Cz6Dd4F2ngze0jz7tbzrD2wAV+o9FeNHe4rL+yK2md0J/fiSf1sa1ADhXqi5+oVwOM/eGw==", + "dev": true, + "dependencies": { + "semver": "^6.0.0" + }, + "engines": { + "node": ">=8" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/meteor-node-stubs": { + "version": "1.2.10", + "resolved": "https://registry.npmjs.org/meteor-node-stubs/-/meteor-node-stubs-1.2.10.tgz", + "integrity": "sha512-zP1AVg8sOATz15yfy11R2VTx+IZFfAOXi8GuZa8tOfeVT1tKaqDooAbFylnIXwpStSu6HRBUhQqHtR06Qr9aEA==", + "bundleDependencies": [ + "@meteorjs/crypto-browserify", + "assert", + "browserify-zlib", + "buffer", + "console-browserify", + "constants-browserify", + "domain-browser", + "events", + "https-browserify", + "os-browserify", + "path-browserify", + "process", + "punycode", + "querystring-es3", + "readable-stream", + "stream-browserify", + "stream-http", + "string_decoder", + "timers-browserify", + "tty-browserify", + "url", + "util", + "vm-browserify" + ], + "dependencies": { + "@meteorjs/crypto-browserify": "^3.12.1", + "assert": "^2.1.0", + "browserify-zlib": "^0.2.0", + "buffer": "^5.7.1", + "console-browserify": "^1.2.0", + "constants-browserify": "^1.0.0", + "domain-browser": "^4.23.0", + "elliptic": "^6.5.7", + "events": "^3.3.0", + "https-browserify": "^1.0.0", + "os-browserify": "^0.3.0", + "path-browserify": "^1.0.1", + "process": "^0.11.10", + "punycode": "^1.4.1", + "querystring-es3": "^0.2.1", + "readable-stream": "^3.6.2", + "stream-browserify": "^3.0.0", + "stream-http": "^3.2.0", + "string_decoder": "^1.3.0", + "timers-browserify": "^2.0.12", + "tty-browserify": "0.0.1", + "url": "^0.11.4", + "util": "^0.12.5", + "vm-browserify": "^1.1.2" + } + }, + "node_modules/meteor-node-stubs/node_modules/@meteorjs/crypto-browserify": { + "version": "3.12.1", + "inBundle": true, + "license": "MIT", + "dependencies": { + "browserify-cipher": "^1.0.1", + "browserify-sign": "^4.2.3", + "create-ecdh": "^4.0.4", + "create-hash": "^1.2.0", + "create-hmac": "^1.1.7", + "diffie-hellman": "^5.0.3", + "hash-base": "~3.0.4", + "inherits": "^2.0.4", + "pbkdf2": "^3.1.2", + "public-encrypt": "^4.0.3", + "randombytes": "^2.1.0", + "randomfill": "^1.0.4" + }, + "engines": { + "node": ">= 0.10" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/meteor-node-stubs/node_modules/@meteorjs/crypto-browserify/node_modules/hash-base": { + "version": "3.0.4", + "inBundle": true, + "license": "MIT", + "dependencies": { + "inherits": "^2.0.1", + "safe-buffer": "^5.0.1" + }, + "engines": { + "node": ">=4" + } + }, + "node_modules/meteor-node-stubs/node_modules/asn1.js": { + "version": "4.10.1", + "inBundle": true, + "license": "MIT", + "dependencies": { + "bn.js": "^4.0.0", + "inherits": "^2.0.1", + "minimalistic-assert": "^1.0.0" + } + }, + "node_modules/meteor-node-stubs/node_modules/asn1.js/node_modules/bn.js": { + "version": "4.12.0", + "inBundle": true, + "license": "MIT" + }, + "node_modules/meteor-node-stubs/node_modules/assert": { + "version": "2.1.0", + "inBundle": true, + "license": "MIT", + "dependencies": { + "call-bind": "^1.0.2", + "is-nan": "^1.3.2", + "object-is": "^1.1.5", + "object.assign": "^4.1.4", + "util": "^0.12.5" + } + }, + "node_modules/meteor-node-stubs/node_modules/available-typed-arrays": { + "version": "1.0.5", + "inBundle": true, + "license": "MIT", + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/meteor-node-stubs/node_modules/base64-js": { + "version": "1.5.1", + "funding": [ + { + "type": "github", + "url": "https://github.com/sponsors/feross" + }, + { + "type": "patreon", + "url": "https://www.patreon.com/feross" + }, + { + "type": "consulting", + "url": "https://feross.org/support" + } + ], + "inBundle": true, + "license": "MIT" + }, + "node_modules/meteor-node-stubs/node_modules/bn.js": { + "version": "5.2.0", + "inBundle": true, + "license": "MIT" + }, + "node_modules/meteor-node-stubs/node_modules/brorand": { + "version": "1.1.0", + "inBundle": true, + "license": "MIT" + }, + "node_modules/meteor-node-stubs/node_modules/browserify-aes": { + "version": "1.2.0", + "inBundle": true, + "license": "MIT", + "dependencies": { + "buffer-xor": "^1.0.3", + "cipher-base": "^1.0.0", + "create-hash": "^1.1.0", + "evp_bytestokey": "^1.0.3", + "inherits": "^2.0.1", + "safe-buffer": "^5.0.1" + } + }, + "node_modules/meteor-node-stubs/node_modules/browserify-cipher": { + "version": "1.0.1", + "inBundle": true, + "license": "MIT", + "dependencies": { + "browserify-aes": "^1.0.4", + "browserify-des": "^1.0.0", + "evp_bytestokey": "^1.0.0" + } + }, + "node_modules/meteor-node-stubs/node_modules/browserify-des": { + "version": "1.0.2", + "inBundle": true, + "license": "MIT", + "dependencies": { + "cipher-base": "^1.0.1", + "des.js": "^1.0.0", + "inherits": "^2.0.1", + "safe-buffer": "^5.1.2" + } + }, + "node_modules/meteor-node-stubs/node_modules/browserify-rsa": { + "version": "4.1.0", + "inBundle": true, + "license": "MIT", + "dependencies": { + "bn.js": "^5.0.0", + "randombytes": "^2.0.1" + } + }, + "node_modules/meteor-node-stubs/node_modules/browserify-sign": { + "version": "4.2.3", + "inBundle": true, + "license": "ISC", + "dependencies": { + "bn.js": "^5.2.1", + "browserify-rsa": "^4.1.0", + "create-hash": "^1.2.0", + "create-hmac": "^1.1.7", + "elliptic": "^6.5.5", + "hash-base": "~3.0", + "inherits": "^2.0.4", + "parse-asn1": "^5.1.7", + "readable-stream": "^2.3.8", + "safe-buffer": "^5.2.1" + }, + "engines": { + "node": ">= 0.12" + } + }, + "node_modules/meteor-node-stubs/node_modules/browserify-sign/node_modules/bn.js": { + "version": "5.2.1", + "inBundle": true, + "license": "MIT" + }, + "node_modules/meteor-node-stubs/node_modules/browserify-sign/node_modules/hash-base": { + "version": "3.0.4", + "inBundle": true, + "license": "MIT", + "dependencies": { + "inherits": "^2.0.1", + "safe-buffer": "^5.0.1" + }, + "engines": { + "node": ">=4" + } + }, + "node_modules/meteor-node-stubs/node_modules/browserify-sign/node_modules/readable-stream": { + "version": "2.3.8", + "inBundle": true, + "license": "MIT", + "dependencies": { + "core-util-is": "~1.0.0", + "inherits": "~2.0.3", + "isarray": "~1.0.0", + "process-nextick-args": "~2.0.0", + "safe-buffer": "~5.1.1", + "string_decoder": "~1.1.1", + "util-deprecate": "~1.0.1" + } + }, + "node_modules/meteor-node-stubs/node_modules/browserify-sign/node_modules/readable-stream/node_modules/safe-buffer": { + "version": "5.1.2", + "inBundle": true, + "license": "MIT" + }, + "node_modules/meteor-node-stubs/node_modules/browserify-sign/node_modules/string_decoder": { + "version": "1.1.1", + "inBundle": true, + "license": "MIT", + "dependencies": { + "safe-buffer": "~5.1.0" + } + }, + "node_modules/meteor-node-stubs/node_modules/browserify-sign/node_modules/string_decoder/node_modules/safe-buffer": { + "version": "5.1.2", + "inBundle": true, + "license": "MIT" + }, + "node_modules/meteor-node-stubs/node_modules/browserify-zlib": { + "version": "0.2.0", + "inBundle": true, + "license": "MIT", + "dependencies": { + "pako": "~1.0.5" + } + }, + "node_modules/meteor-node-stubs/node_modules/buffer": { + "version": "5.7.1", + "funding": [ + { + "type": "github", + "url": "https://github.com/sponsors/feross" + }, + { + "type": "patreon", + "url": "https://www.patreon.com/feross" + }, + { + "type": "consulting", + "url": "https://feross.org/support" + } + ], + "inBundle": true, + "license": "MIT", + "dependencies": { + "base64-js": "^1.3.1", + "ieee754": "^1.1.13" + } + }, + "node_modules/meteor-node-stubs/node_modules/buffer-xor": { + "version": "1.0.3", + "inBundle": true, + "license": "MIT" + }, + "node_modules/meteor-node-stubs/node_modules/builtin-status-codes": { + "version": "3.0.0", + "inBundle": true, + "license": "MIT" + }, + "node_modules/meteor-node-stubs/node_modules/call-bind": { + "version": "1.0.7", + "inBundle": true, + "license": "MIT", + "dependencies": { + "es-define-property": "^1.0.0", + "es-errors": "^1.3.0", + "function-bind": "^1.1.2", + "get-intrinsic": "^1.2.4", + "set-function-length": "^1.2.1" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/meteor-node-stubs/node_modules/cipher-base": { + "version": "1.0.4", + "inBundle": true, + "license": "MIT", + "dependencies": { + "inherits": "^2.0.1", + "safe-buffer": "^5.0.1" + } + }, + "node_modules/meteor-node-stubs/node_modules/console-browserify": { + "version": "1.2.0", + "inBundle": true + }, + "node_modules/meteor-node-stubs/node_modules/constants-browserify": { + "version": "1.0.0", + "inBundle": true, + "license": "MIT" + }, + "node_modules/meteor-node-stubs/node_modules/core-util-is": { + "version": "1.0.3", + "inBundle": true, + "license": "MIT" + }, + "node_modules/meteor-node-stubs/node_modules/create-ecdh": { + "version": "4.0.4", + "inBundle": true, + "license": "MIT", + "dependencies": { + "bn.js": "^4.1.0", + "elliptic": "^6.5.3" + } + }, + "node_modules/meteor-node-stubs/node_modules/create-ecdh/node_modules/bn.js": { + "version": "4.12.0", + "inBundle": true, + "license": "MIT" + }, + "node_modules/meteor-node-stubs/node_modules/create-hash": { + "version": "1.2.0", + "inBundle": true, + "license": "MIT", + "dependencies": { + "cipher-base": "^1.0.1", + "inherits": "^2.0.1", + "md5.js": "^1.3.4", + "ripemd160": "^2.0.1", + "sha.js": "^2.4.0" + } + }, + "node_modules/meteor-node-stubs/node_modules/create-hmac": { + "version": "1.1.7", + "inBundle": true, + "license": "MIT", + "dependencies": { + "cipher-base": "^1.0.3", + "create-hash": "^1.1.0", + "inherits": "^2.0.1", + "ripemd160": "^2.0.0", + "safe-buffer": "^5.0.1", + "sha.js": "^2.4.8" + } + }, + "node_modules/meteor-node-stubs/node_modules/define-data-property": { + "version": "1.1.4", + "inBundle": true, + "license": "MIT", + "dependencies": { + "es-define-property": "^1.0.0", + "es-errors": "^1.3.0", + "gopd": "^1.0.1" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/meteor-node-stubs/node_modules/define-properties": { + "version": "1.2.1", + "inBundle": true, + "license": "MIT", + "dependencies": { + "define-data-property": "^1.0.1", + "has-property-descriptors": "^1.0.0", + "object-keys": "^1.1.1" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/meteor-node-stubs/node_modules/des.js": { + "version": "1.0.1", + "inBundle": true, + "license": "MIT", + "dependencies": { + "inherits": "^2.0.1", + "minimalistic-assert": "^1.0.0" + } + }, + "node_modules/meteor-node-stubs/node_modules/diffie-hellman": { + "version": "5.0.3", + "inBundle": true, + "license": "MIT", + "dependencies": { + "bn.js": "^4.1.0", + "miller-rabin": "^4.0.0", + "randombytes": "^2.0.0" + } + }, + "node_modules/meteor-node-stubs/node_modules/diffie-hellman/node_modules/bn.js": { + "version": "4.12.0", + "inBundle": true, + "license": "MIT" + }, + "node_modules/meteor-node-stubs/node_modules/domain-browser": { + "version": "4.23.0", + "inBundle": true, + "license": "Artistic-2.0", + "engines": { + "node": ">=10" + }, + "funding": { + "url": "https://bevry.me/fund" + } + }, + "node_modules/meteor-node-stubs/node_modules/elliptic": { + "version": "6.5.7", + "inBundle": true, + "license": "MIT", + "dependencies": { + "bn.js": "^4.11.9", + "brorand": "^1.1.0", + "hash.js": "^1.0.0", + "hmac-drbg": "^1.0.1", + "inherits": "^2.0.4", + "minimalistic-assert": "^1.0.1", + "minimalistic-crypto-utils": "^1.0.1" + } + }, + "node_modules/meteor-node-stubs/node_modules/elliptic/node_modules/bn.js": { + "version": "4.12.0", + "inBundle": true, + "license": "MIT" + }, + "node_modules/meteor-node-stubs/node_modules/es-define-property": { + "version": "1.0.0", + "inBundle": true, + "license": "MIT", + "dependencies": { + "get-intrinsic": "^1.2.4" + }, + "engines": { + "node": ">= 0.4" + } + }, + "node_modules/meteor-node-stubs/node_modules/es-errors": { + "version": "1.3.0", + "inBundle": true, + "license": "MIT", + "engines": { + "node": ">= 0.4" + } + }, + "node_modules/meteor-node-stubs/node_modules/events": { + "version": "3.3.0", + "inBundle": true, + "license": "MIT", + "engines": { + "node": ">=0.8.x" + } + }, + "node_modules/meteor-node-stubs/node_modules/evp_bytestokey": { + "version": "1.0.3", + "inBundle": true, + "license": "MIT", + "dependencies": { + "md5.js": "^1.3.4", + "safe-buffer": "^5.1.1" + } + }, + "node_modules/meteor-node-stubs/node_modules/for-each": { + "version": "0.3.3", + "inBundle": true, + "license": "MIT", + "dependencies": { + "is-callable": "^1.1.3" + } + }, + "node_modules/meteor-node-stubs/node_modules/function-bind": { + "version": "1.1.2", + "inBundle": true, + "license": "MIT", + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/meteor-node-stubs/node_modules/get-intrinsic": { + "version": "1.2.4", + "inBundle": true, + "license": "MIT", + "dependencies": { + "es-errors": "^1.3.0", + "function-bind": "^1.1.2", + "has-proto": "^1.0.1", + "has-symbols": "^1.0.3", + "hasown": "^2.0.0" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/meteor-node-stubs/node_modules/gopd": { + "version": "1.0.1", + "inBundle": true, + "license": "MIT", + "dependencies": { + "get-intrinsic": "^1.1.3" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/meteor-node-stubs/node_modules/has-property-descriptors": { + "version": "1.0.2", + "inBundle": true, + "license": "MIT", + "dependencies": { + "es-define-property": "^1.0.0" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/meteor-node-stubs/node_modules/has-proto": { + "version": "1.0.1", + "inBundle": true, + "license": "MIT", + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/meteor-node-stubs/node_modules/has-symbols": { + "version": "1.0.3", + "inBundle": true, + "license": "MIT", + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/meteor-node-stubs/node_modules/has-tostringtag": { + "version": "1.0.0", + "inBundle": true, + "license": "MIT", + "dependencies": { + "has-symbols": "^1.0.2" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/meteor-node-stubs/node_modules/hash-base": { + "version": "3.1.0", + "inBundle": true, + "license": "MIT", + "dependencies": { + "inherits": "^2.0.4", + "readable-stream": "^3.6.0", + "safe-buffer": "^5.2.0" + }, + "engines": { + "node": ">=4" + } + }, + "node_modules/meteor-node-stubs/node_modules/hash.js": { + "version": "1.1.7", + "inBundle": true, + "license": "MIT", + "dependencies": { + "inherits": "^2.0.3", + "minimalistic-assert": "^1.0.1" + } + }, + "node_modules/meteor-node-stubs/node_modules/hasown": { + "version": "2.0.0", + "inBundle": true, + "license": "MIT", + "dependencies": { + "function-bind": "^1.1.2" + }, + "engines": { + "node": ">= 0.4" + } + }, + "node_modules/meteor-node-stubs/node_modules/hmac-drbg": { + "version": "1.0.1", + "inBundle": true, + "license": "MIT", + "dependencies": { + "hash.js": "^1.0.3", + "minimalistic-assert": "^1.0.0", + "minimalistic-crypto-utils": "^1.0.1" + } + }, + "node_modules/meteor-node-stubs/node_modules/https-browserify": { + "version": "1.0.0", + "inBundle": true, + "license": "MIT" + }, + "node_modules/meteor-node-stubs/node_modules/ieee754": { + "version": "1.2.1", + "funding": [ + { + "type": "github", + "url": "https://github.com/sponsors/feross" + }, + { + "type": "patreon", + "url": "https://www.patreon.com/feross" + }, + { + "type": "consulting", + "url": "https://feross.org/support" + } + ], + "inBundle": true, + "license": "BSD-3-Clause" + }, + "node_modules/meteor-node-stubs/node_modules/inherits": { + "version": "2.0.4", + "inBundle": true, + "license": "ISC" + }, + "node_modules/meteor-node-stubs/node_modules/is-arguments": { + "version": "1.1.1", + "inBundle": true, + "license": "MIT", + "dependencies": { + "call-bind": "^1.0.2", + "has-tostringtag": "^1.0.0" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/meteor-node-stubs/node_modules/is-callable": { + "version": "1.2.7", + "inBundle": true, + "license": "MIT", + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/meteor-node-stubs/node_modules/is-generator-function": { + "version": "1.0.10", + "inBundle": true, + "license": "MIT", + "dependencies": { + "has-tostringtag": "^1.0.0" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/meteor-node-stubs/node_modules/is-nan": { + "version": "1.3.2", + "inBundle": true, + "license": "MIT", + "dependencies": { + "call-bind": "^1.0.0", + "define-properties": "^1.1.3" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/meteor-node-stubs/node_modules/is-typed-array": { + "version": "1.1.12", + "inBundle": true, + "license": "MIT", + "dependencies": { + "which-typed-array": "^1.1.11" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/meteor-node-stubs/node_modules/isarray": { + "version": "1.0.0", + "inBundle": true, + "license": "MIT" + }, + "node_modules/meteor-node-stubs/node_modules/md5.js": { + "version": "1.3.5", + "inBundle": true, + "license": "MIT", + "dependencies": { + "hash-base": "^3.0.0", + "inherits": "^2.0.1", + "safe-buffer": "^5.1.2" + } + }, + "node_modules/meteor-node-stubs/node_modules/miller-rabin": { + "version": "4.0.1", + "inBundle": true, + "license": "MIT", + "dependencies": { + "bn.js": "^4.0.0", + "brorand": "^1.0.1" + }, + "bin": { + "miller-rabin": "bin/miller-rabin" + } + }, + "node_modules/meteor-node-stubs/node_modules/miller-rabin/node_modules/bn.js": { + "version": "4.12.0", + "inBundle": true, + "license": "MIT" + }, + "node_modules/meteor-node-stubs/node_modules/minimalistic-assert": { + "version": "1.0.1", + "inBundle": true, + "license": "ISC" + }, + "node_modules/meteor-node-stubs/node_modules/minimalistic-crypto-utils": { + "version": "1.0.1", + "inBundle": true, + "license": "MIT" + }, + "node_modules/meteor-node-stubs/node_modules/object-inspect": { + "version": "1.13.2", + "inBundle": true, + "license": "MIT", + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/meteor-node-stubs/node_modules/object-is": { + "version": "1.1.5", + "inBundle": true, + "license": "MIT", + "dependencies": { + "call-bind": "^1.0.2", + "define-properties": "^1.1.3" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/meteor-node-stubs/node_modules/object-keys": { + "version": "1.1.1", + "inBundle": true, + "license": "MIT", + "engines": { + "node": ">= 0.4" + } + }, + "node_modules/meteor-node-stubs/node_modules/object.assign": { + "version": "4.1.4", + "inBundle": true, + "license": "MIT", + "dependencies": { + "call-bind": "^1.0.2", + "define-properties": "^1.1.4", + "has-symbols": "^1.0.3", + "object-keys": "^1.1.1" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/meteor-node-stubs/node_modules/os-browserify": { + "version": "0.3.0", + "inBundle": true, + "license": "MIT" + }, + "node_modules/meteor-node-stubs/node_modules/pako": { + "version": "1.0.11", + "inBundle": true, + "license": "(MIT AND Zlib)" + }, + "node_modules/meteor-node-stubs/node_modules/parse-asn1": { + "version": "5.1.7", + "inBundle": true, + "license": "ISC", + "dependencies": { + "asn1.js": "^4.10.1", + "browserify-aes": "^1.2.0", + "evp_bytestokey": "^1.0.3", + "hash-base": "~3.0", + "pbkdf2": "^3.1.2", + "safe-buffer": "^5.2.1" + }, + "engines": { + "node": ">= 0.10" + } + }, + "node_modules/meteor-node-stubs/node_modules/parse-asn1/node_modules/hash-base": { + "version": "3.0.4", + "inBundle": true, + "license": "MIT", + "dependencies": { + "inherits": "^2.0.1", + "safe-buffer": "^5.0.1" + }, + "engines": { + "node": ">=4" + } + }, + "node_modules/meteor-node-stubs/node_modules/path-browserify": { + "version": "1.0.1", + "inBundle": true, + "license": "MIT" + }, + "node_modules/meteor-node-stubs/node_modules/pbkdf2": { + "version": "3.1.2", + "inBundle": true, + "license": "MIT", + "dependencies": { + "create-hash": "^1.1.2", + "create-hmac": "^1.1.4", + "ripemd160": "^2.0.1", + "safe-buffer": "^5.0.1", + "sha.js": "^2.4.8" + }, + "engines": { + "node": ">=0.12" + } + }, + "node_modules/meteor-node-stubs/node_modules/process": { + "version": "0.11.10", + "inBundle": true, + "license": "MIT", + "engines": { + "node": ">= 0.6.0" + } + }, + "node_modules/meteor-node-stubs/node_modules/process-nextick-args": { + "version": "2.0.1", + "inBundle": true, + "license": "MIT" + }, + "node_modules/meteor-node-stubs/node_modules/public-encrypt": { + "version": "4.0.3", + "inBundle": true, + "license": "MIT", + "dependencies": { + "bn.js": "^4.1.0", + "browserify-rsa": "^4.0.0", + "create-hash": "^1.1.0", + "parse-asn1": "^5.0.0", + "randombytes": "^2.0.1", + "safe-buffer": "^5.1.2" + } + }, + "node_modules/meteor-node-stubs/node_modules/public-encrypt/node_modules/bn.js": { + "version": "4.12.0", + "inBundle": true, + "license": "MIT" + }, + "node_modules/meteor-node-stubs/node_modules/punycode": { + "version": "1.4.1", + "inBundle": true, + "license": "MIT" + }, + "node_modules/meteor-node-stubs/node_modules/qs": { + "version": "6.13.0", + "inBundle": true, + "license": "BSD-3-Clause", + "dependencies": { + "side-channel": "^1.0.6" + }, + "engines": { + "node": ">=0.6" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/meteor-node-stubs/node_modules/querystring-es3": { + "version": "0.2.1", + "inBundle": true, + "engines": { + "node": ">=0.4.x" + } + }, + "node_modules/meteor-node-stubs/node_modules/randombytes": { + "version": "2.1.0", + "inBundle": true, + "license": "MIT", + "dependencies": { + "safe-buffer": "^5.1.0" + } + }, + "node_modules/meteor-node-stubs/node_modules/randomfill": { + "version": "1.0.4", + "inBundle": true, + "license": "MIT", + "dependencies": { + "randombytes": "^2.0.5", + "safe-buffer": "^5.1.0" + } + }, + "node_modules/meteor-node-stubs/node_modules/readable-stream": { + "version": "3.6.2", + "inBundle": true, + "license": "MIT", + "dependencies": { + "inherits": "^2.0.3", + "string_decoder": "^1.1.1", + "util-deprecate": "^1.0.1" + }, + "engines": { + "node": ">= 6" + } + }, + "node_modules/meteor-node-stubs/node_modules/ripemd160": { + "version": "2.0.2", + "inBundle": true, + "license": "MIT", + "dependencies": { + "hash-base": "^3.0.0", + "inherits": "^2.0.1" + } + }, + "node_modules/meteor-node-stubs/node_modules/safe-buffer": { + "version": "5.2.1", + "funding": [ + { + "type": "github", + "url": "https://github.com/sponsors/feross" + }, + { + "type": "patreon", + "url": "https://www.patreon.com/feross" + }, + { + "type": "consulting", + "url": "https://feross.org/support" + } + ], + "inBundle": true, + "license": "MIT" + }, + "node_modules/meteor-node-stubs/node_modules/set-function-length": { + "version": "1.2.2", + "inBundle": true, + "license": "MIT", + "dependencies": { + "define-data-property": "^1.1.4", + "es-errors": "^1.3.0", + "function-bind": "^1.1.2", + "get-intrinsic": "^1.2.4", + "gopd": "^1.0.1", + "has-property-descriptors": "^1.0.2" + }, + "engines": { + "node": ">= 0.4" + } + }, + "node_modules/meteor-node-stubs/node_modules/setimmediate": { + "version": "1.0.5", + "inBundle": true, + "license": "MIT" + }, + "node_modules/meteor-node-stubs/node_modules/sha.js": { + "version": "2.4.11", + "inBundle": true, + "license": "(MIT AND BSD-3-Clause)", + "dependencies": { + "inherits": "^2.0.1", + "safe-buffer": "^5.0.1" + }, + "bin": { + "sha.js": "bin.js" + } + }, + "node_modules/meteor-node-stubs/node_modules/side-channel": { + "version": "1.0.6", + "inBundle": true, + "license": "MIT", + "dependencies": { + "call-bind": "^1.0.7", + "es-errors": "^1.3.0", + "get-intrinsic": "^1.2.4", + "object-inspect": "^1.13.1" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/meteor-node-stubs/node_modules/stream-browserify": { + "version": "3.0.0", + "inBundle": true, + "license": "MIT", + "dependencies": { + "inherits": "~2.0.4", + "readable-stream": "^3.5.0" + } + }, + "node_modules/meteor-node-stubs/node_modules/stream-http": { + "version": "3.2.0", + "inBundle": true, + "license": "MIT", + "dependencies": { + "builtin-status-codes": "^3.0.0", + "inherits": "^2.0.4", + "readable-stream": "^3.6.0", + "xtend": "^4.0.2" + } + }, + "node_modules/meteor-node-stubs/node_modules/string_decoder": { + "version": "1.3.0", + "inBundle": true, + "license": "MIT", + "dependencies": { + "safe-buffer": "~5.2.0" + } + }, + "node_modules/meteor-node-stubs/node_modules/timers-browserify": { + "version": "2.0.12", + "inBundle": true, + "license": "MIT", + "dependencies": { + "setimmediate": "^1.0.4" + }, + "engines": { + "node": ">=0.6.0" + } + }, + "node_modules/meteor-node-stubs/node_modules/tty-browserify": { + "version": "0.0.1", + "inBundle": true, + "license": "MIT" + }, + "node_modules/meteor-node-stubs/node_modules/url": { + "version": "0.11.4", + "inBundle": true, + "license": "MIT", + "dependencies": { + "punycode": "^1.4.1", + "qs": "^6.12.3" + }, + "engines": { + "node": ">= 0.4" + } + }, + "node_modules/meteor-node-stubs/node_modules/util": { + "version": "0.12.5", + "inBundle": true, + "license": "MIT", + "dependencies": { + "inherits": "^2.0.3", + "is-arguments": "^1.0.4", + "is-generator-function": "^1.0.7", + "is-typed-array": "^1.1.3", + "which-typed-array": "^1.1.2" + } + }, + "node_modules/meteor-node-stubs/node_modules/util-deprecate": { + "version": "1.0.2", + "inBundle": true, + "license": "MIT" + }, + "node_modules/meteor-node-stubs/node_modules/vm-browserify": { + "version": "1.1.2", + "inBundle": true, + "license": "MIT" + }, + "node_modules/meteor-node-stubs/node_modules/which-typed-array": { + "version": "1.1.13", + "inBundle": true, + "license": "MIT", + "dependencies": { + "available-typed-arrays": "^1.0.5", + "call-bind": "^1.0.4", + "for-each": "^0.3.3", + "gopd": "^1.0.1", + "has-tostringtag": "^1.0.0" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/meteor-node-stubs/node_modules/xtend": { + "version": "4.0.2", + "inBundle": true, + "license": "MIT", + "engines": { + "node": ">=0.4" + } + }, + "node_modules/minimatch": { + "version": "3.1.2", + "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.1.2.tgz", + "integrity": "sha512-J7p63hRiAjw1NDEww1W7i37+ByIrOWO5XQQAzZ3VOcL0PNybwpfmV/N05zFAzwQ9USyEcX6t3UO+K5aqBQOIHw==", + "dev": true, + "dependencies": { + "brace-expansion": "^1.1.7" + }, + "engines": { + "node": "*" + } + }, + "node_modules/minimist": { + "version": "1.2.8", + "resolved": "https://registry.npmjs.org/minimist/-/minimist-1.2.8.tgz", + "integrity": "sha512-2yyAR8qBkN3YuheJanUpWC5U3bb5osDywNB8RzDVlDwDHbocAJveqqj1u8+SVD7jkWT4yvsHCpWqqWqAxb0zCA==", + "dev": true, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/mitt": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/mitt/-/mitt-3.0.0.tgz", + "integrity": "sha512-7dX2/10ITVyqh4aOSVI9gdape+t9l2/8QxHrFmUXu4EEUpdlxl6RudZUPZoc+zuY2hk1j7XxVroIVIan/pD/SQ==", + "dev": true + }, + "node_modules/mkdirp-classic": { + "version": "0.5.3", + "resolved": "https://registry.npmjs.org/mkdirp-classic/-/mkdirp-classic-0.5.3.tgz", + "integrity": "sha512-gKLcREMhtuZRwRAfqP3RFW+TK4JqApVBtOIftVgjuABpAtpxhPGaDcfvbhNvD0B8iD1oUr/txX35NjcaY6Ns/A==", + "dev": true + }, + "node_modules/ms": { + "version": "2.1.2", + "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", + "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==", + "dev": true + }, + "node_modules/natural-compare": { + "version": "1.4.0", + "resolved": "https://registry.npmjs.org/natural-compare/-/natural-compare-1.4.0.tgz", + "integrity": "sha512-OWND8ei3VtNC9h7V60qff3SVobHr996CTwgxubgyQYEpg290h9J0buyECNNJexkFm5sOajh5G116RYA1c8ZMSw==", + "dev": true + }, + "node_modules/node-fetch": { + "version": "2.6.7", + "resolved": "https://registry.npmjs.org/node-fetch/-/node-fetch-2.6.7.tgz", + "integrity": "sha512-ZjMPFEfVx5j+y2yF35Kzx5sF7kDzxuDj6ziH4FFbOp87zKDZNx8yExJIb05OGF4Nlt9IHFIMBkRl41VdvcNdbQ==", + "dev": true, + "dependencies": { + "whatwg-url": "^5.0.0" + }, + "engines": { + "node": "4.x || >=6.0.0" + }, + "peerDependencies": { + "encoding": "^0.1.0" + }, + "peerDependenciesMeta": { + "encoding": { + "optional": true + } + } + }, + "node_modules/node-preload": { + "version": "0.2.1", + "resolved": "https://registry.npmjs.org/node-preload/-/node-preload-0.2.1.tgz", + "integrity": "sha512-RM5oyBy45cLEoHqCeh+MNuFAxO0vTFBLskvQbOKnEE7YTTSN4tbN8QWDIPQ6L+WvKsB/qLEGpYe2ZZ9d4W9OIQ==", + "dev": true, + "dependencies": { + "process-on-spawn": "^1.0.0" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/node-releases": { + "version": "2.0.18", + "resolved": "https://registry.npmjs.org/node-releases/-/node-releases-2.0.18.tgz", + "integrity": "sha512-d9VeXT4SJ7ZeOqGX6R5EM022wpL+eWPooLI+5UpWn2jCT1aosUQEhQP214x33Wkwx3JQMvIm+tIoVOdodFS40g==", + "dev": true + }, + "node_modules/nyc": { + "version": "15.1.0", + "resolved": "https://registry.npmjs.org/nyc/-/nyc-15.1.0.tgz", + "integrity": "sha512-jMW04n9SxKdKi1ZMGhvUTHBN0EICCRkHemEoE5jm6mTYcqcdas0ATzgUgejlQUHMvpnOZqGB5Xxsv9KxJW1j8A==", + "dev": true, + "dependencies": { + "@istanbuljs/load-nyc-config": "^1.0.0", + "@istanbuljs/schema": "^0.1.2", + "caching-transform": "^4.0.0", + "convert-source-map": "^1.7.0", + "decamelize": "^1.2.0", + "find-cache-dir": "^3.2.0", + "find-up": "^4.1.0", + "foreground-child": "^2.0.0", + "get-package-type": "^0.1.0", + "glob": "^7.1.6", + "istanbul-lib-coverage": "^3.0.0", + "istanbul-lib-hook": "^3.0.0", + "istanbul-lib-instrument": "^4.0.0", + "istanbul-lib-processinfo": "^2.0.2", + "istanbul-lib-report": "^3.0.0", + "istanbul-lib-source-maps": "^4.0.0", + "istanbul-reports": "^3.0.2", + "make-dir": "^3.0.0", + "node-preload": "^0.2.1", + "p-map": "^3.0.0", + "process-on-spawn": "^1.0.0", + "resolve-from": "^5.0.0", + "rimraf": "^3.0.0", + "signal-exit": "^3.0.2", + "spawn-wrap": "^2.0.0", + "test-exclude": "^6.0.0", + "yargs": "^15.0.2" + }, + "bin": { + "nyc": "bin/nyc.js" + }, + "engines": { + "node": ">=8.9" + } + }, + "node_modules/nyc/node_modules/convert-source-map": { + "version": "1.9.0", + "resolved": "https://registry.npmjs.org/convert-source-map/-/convert-source-map-1.9.0.tgz", + "integrity": "sha512-ASFBup0Mz1uyiIjANan1jzLQami9z1PoYSZCiiYW2FczPbenXc45FZdBZLzOT+r6+iciuEModtmCti+hjaAk0A==", + "dev": true + }, + "node_modules/nyc/node_modules/istanbul-lib-instrument": { + "version": "4.0.3", + "resolved": "https://registry.npmjs.org/istanbul-lib-instrument/-/istanbul-lib-instrument-4.0.3.tgz", + "integrity": "sha512-BXgQl9kf4WTCPCCpmFGoJkz/+uhvm7h7PFKUYxh7qarQd3ER33vHG//qaE8eN25l07YqZPpHXU9I09l/RD5aGQ==", + "dev": true, + "dependencies": { + "@babel/core": "^7.7.5", + "@istanbuljs/schema": "^0.1.2", + "istanbul-lib-coverage": "^3.0.0", + "semver": "^6.3.0" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/object-assign": { + "version": "4.1.1", + "resolved": "https://registry.npmjs.org/object-assign/-/object-assign-4.1.1.tgz", + "integrity": "sha512-rJgTQnkUnH1sFw8yT6VSU3zD3sWmu6sZhIseY8VX+GRu3P6F7Fu+JNDoXfklElbLJSnc3FUQHVe4cU5hj+BcUg==", + "dev": true, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/object-inspect": { + "version": "1.13.2", + "resolved": "https://registry.npmjs.org/object-inspect/-/object-inspect-1.13.2.tgz", + "integrity": "sha512-IRZSRuzJiynemAXPYtPe5BoI/RESNYR7TYm50MC5Mqbd3Jmw5y790sErYw3V6SryFJD64b74qQQs9wn5Bg/k3g==", + "dev": true, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/object-keys": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/object-keys/-/object-keys-1.1.1.tgz", + "integrity": "sha512-NuAESUOUMrlIXOfHKzD6bpPu3tYt3xvjNdRIQ+FeT0lNb4K8WR70CaDxhuNguS2XG+GjkyMwOzsN5ZktImfhLA==", + "dev": true, + "engines": { + "node": ">= 0.4" + } + }, + "node_modules/object.assign": { + "version": "4.1.5", + "resolved": "https://registry.npmjs.org/object.assign/-/object.assign-4.1.5.tgz", + "integrity": "sha512-byy+U7gp+FVwmyzKPYhW2h5l3crpmGsxl7X2s8y43IgxvG4g3QZ6CffDtsNQy1WsmZpQbO+ybo0AlW7TY6DcBQ==", + "dev": true, + "dependencies": { + "call-bind": "^1.0.5", + "define-properties": "^1.2.1", + "has-symbols": "^1.0.3", + "object-keys": "^1.1.1" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/object.entries": { + "version": "1.1.8", + "resolved": "https://registry.npmjs.org/object.entries/-/object.entries-1.1.8.tgz", + "integrity": "sha512-cmopxi8VwRIAw/fkijJohSfpef5PdN0pMQJN6VC/ZKvn0LIknWD8KtgY6KlQdEc4tIjcQ3HxSMmnvtzIscdaYQ==", + "dev": true, + "dependencies": { + "call-bind": "^1.0.7", + "define-properties": "^1.2.1", + "es-object-atoms": "^1.0.0" + }, + "engines": { + "node": ">= 0.4" + } + }, + "node_modules/object.fromentries": { + "version": "2.0.8", + "resolved": "https://registry.npmjs.org/object.fromentries/-/object.fromentries-2.0.8.tgz", + "integrity": "sha512-k6E21FzySsSK5a21KRADBd/NGneRegFO5pLHfdQLpRDETUNJueLXs3WCzyQ3tFRDYgbq3KHGXfTbi2bs8WQ6rQ==", + "dev": true, + "dependencies": { + "call-bind": "^1.0.7", + "define-properties": "^1.2.1", + "es-abstract": "^1.23.2", + "es-object-atoms": "^1.0.0" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/object.groupby": { + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/object.groupby/-/object.groupby-1.0.3.tgz", + "integrity": "sha512-+Lhy3TQTuzXI5hevh8sBGqbmurHbbIjAi0Z4S63nthVLmLxfbj4T54a4CfZrXIrt9iP4mVAPYMo/v99taj3wjQ==", + "dev": true, + "dependencies": { + "call-bind": "^1.0.7", + "define-properties": "^1.2.1", + "es-abstract": "^1.23.2" + }, + "engines": { + "node": ">= 0.4" + } + }, + "node_modules/object.values": { + "version": "1.2.0", + "resolved": "https://registry.npmjs.org/object.values/-/object.values-1.2.0.tgz", + "integrity": "sha512-yBYjY9QX2hnRmZHAjG/f13MzmBzxzYgQhFrke06TTyKY5zSTEqkOeukBzIdVA3j3ulu8Qa3MbVFShV7T2RmGtQ==", + "dev": true, + "dependencies": { + "call-bind": "^1.0.7", + "define-properties": "^1.2.1", + "es-object-atoms": "^1.0.0" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/once": { + "version": "1.4.0", + "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz", + "integrity": "sha512-lNaJgI+2Q5URQBkccEKHTQOPaXdUxnZZElQTZY0MFUAuaEqe1E+Nyvgdz/aIyNi6Z9MzO5dv1H8n58/GELp3+w==", + "dev": true, + "dependencies": { + "wrappy": "1" + } + }, + "node_modules/optionator": { + "version": "0.9.4", + "resolved": "https://registry.npmjs.org/optionator/-/optionator-0.9.4.tgz", + "integrity": "sha512-6IpQ7mKUxRcZNLIObR0hz7lxsapSSIYNZJwXPGeF0mTVqGKFIXj1DQcMoT22S3ROcLyY/rz0PWaWZ9ayWmad9g==", + "dev": true, + "dependencies": { + "deep-is": "^0.1.3", + "fast-levenshtein": "^2.0.6", + "levn": "^0.4.1", + "prelude-ls": "^1.2.1", + "type-check": "^0.4.0", + "word-wrap": "^1.2.5" + }, + "engines": { + "node": ">= 0.8.0" + } + }, + "node_modules/p-limit": { + "version": "2.3.0", + "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-2.3.0.tgz", + "integrity": "sha512-//88mFWSJx8lxCzwdAABTJL2MyWB12+eIY7MDL2SqLmAkeKU9qxRvWuSyTjm3FUmpBEMuFfckAIqEaVGUDxb6w==", + "dev": true, + "dependencies": { + "p-try": "^2.0.0" + }, + "engines": { + "node": ">=6" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/p-locate": { + "version": "4.1.0", + "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-4.1.0.tgz", + "integrity": "sha512-R79ZZ/0wAxKGu3oYMlz8jy/kbhsNrS7SKZ7PxEHBgJ5+F2mtFW2fK2cOtBh1cHYkQsbzFV7I+EoRKe6Yt0oK7A==", + "dev": true, + "dependencies": { + "p-limit": "^2.2.0" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/p-map": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/p-map/-/p-map-3.0.0.tgz", + "integrity": "sha512-d3qXVTF/s+W+CdJ5A29wywV2n8CQQYahlgz2bFiA+4eVNJbHJodPZ+/gXwPGh0bOqA+j8S+6+ckmvLGPk1QpxQ==", + "dev": true, + "dependencies": { + "aggregate-error": "^3.0.0" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/p-try": { + "version": "2.2.0", + "resolved": "https://registry.npmjs.org/p-try/-/p-try-2.2.0.tgz", + "integrity": "sha512-R4nPAVTAU0B9D35/Gk3uJf/7XYbQcyohSKdvAxIRSNghFl4e71hVoGnBNQz9cWaXxO2I10KTC+3jMdvvoKw6dQ==", + "dev": true, + "engines": { + "node": ">=6" + } + }, + "node_modules/package-hash": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/package-hash/-/package-hash-4.0.0.tgz", + "integrity": "sha512-whdkPIooSu/bASggZ96BWVvZTRMOFxnyUG5PnTSGKoJE2gd5mbVNmR2Nj20QFzxYYgAXpoqC+AiXzl+UMRh7zQ==", + "dev": true, + "dependencies": { + "graceful-fs": "^4.1.15", + "hasha": "^5.0.0", + "lodash.flattendeep": "^4.4.0", + "release-zalgo": "^1.0.0" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/parent-module": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/parent-module/-/parent-module-1.0.1.tgz", + "integrity": "sha512-GQ2EWRpQV8/o+Aw8YqtfZZPfNRWZYkbidE9k5rpl/hC3vtHHBfGm2Ifi6qWV+coDGkrUKZAxE3Lot5kcsRlh+g==", + "dev": true, + "dependencies": { + "callsites": "^3.0.0" + }, + "engines": { + "node": ">=6" + } + }, + "node_modules/parse-json": { + "version": "5.2.0", + "resolved": "https://registry.npmjs.org/parse-json/-/parse-json-5.2.0.tgz", + "integrity": "sha512-ayCKvm/phCGxOkYRSCM82iDwct8/EonSEgCSxWxD7ve6jHggsFl4fZVQBPRNgQoKiuV/odhFrGzQXZwbifC8Rg==", + "dev": true, + "dependencies": { + "@babel/code-frame": "^7.0.0", + "error-ex": "^1.3.1", + "json-parse-even-better-errors": "^2.3.0", + "lines-and-columns": "^1.1.6" + }, + "engines": { + "node": ">=8" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/path-exists": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/path-exists/-/path-exists-4.0.0.tgz", + "integrity": "sha512-ak9Qy5Q7jYb2Wwcey5Fpvg2KoAc/ZIhLSLOSBmRmygPsGwkVVt0fZa0qrtMz+m6tJTAHfZQ8FnmB4MG4LWy7/w==", + "dev": true, + "engines": { + "node": ">=8" + } + }, + "node_modules/path-is-absolute": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/path-is-absolute/-/path-is-absolute-1.0.1.tgz", + "integrity": "sha512-AVbw3UJ2e9bq64vSaS9Am0fje1Pa8pbGqTTsmXfaIiMpnr5DlDhfJOuLj9Sf95ZPVDAUerDfEk88MPmPe7UCQg==", + "dev": true, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/path-key": { + "version": "3.1.1", + "resolved": "https://registry.npmjs.org/path-key/-/path-key-3.1.1.tgz", + "integrity": "sha512-ojmeN0qd+y0jszEtoY48r0Peq5dwMEkIlCOu6Q5f41lfkswXuKtYrhgoTpLnyIcHm24Uhqx+5Tqm2InSwLhE6Q==", + "dev": true, + "engines": { + "node": ">=8" + } + }, + "node_modules/path-parse": { + "version": "1.0.7", + "resolved": "https://registry.npmjs.org/path-parse/-/path-parse-1.0.7.tgz", + "integrity": "sha512-LDJzPVEEEPR+y48z93A0Ed0yXb8pAByGWo/k5YYdYgpY2/2EsOsksJrq7lOHxryrVOn1ejG6oAp8ahvOIQD8sw==", + "dev": true + }, + "node_modules/path-type": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/path-type/-/path-type-4.0.0.tgz", + "integrity": "sha512-gDKb8aZMDeD/tZWs9P6+q0J9Mwkdl6xMV8TjnGP3qJVJ06bdMgkbBlLU8IdfOsIsFz2BW1rNVT3XuNEl8zPAvw==", + "dev": true, + "engines": { + "node": ">=8" + } + }, + "node_modules/pathval": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/pathval/-/pathval-1.1.1.tgz", + "integrity": "sha512-Dp6zGqpTdETdR63lehJYPeIOqpiNBNtc7BpWSLrOje7UaIsE5aY92r/AunQA7rsXvet3lrJ3JnZX29UPTKXyKQ==", + "dev": true, + "engines": { + "node": "*" + } + }, + "node_modules/pend": { + "version": "1.2.0", + "resolved": "https://registry.npmjs.org/pend/-/pend-1.2.0.tgz", + "integrity": "sha512-F3asv42UuXchdzt+xXqfW1OGlVBe+mxa2mqI0pg5yAHZPvFmY3Y6drSf/GQ1A86WgWEN9Kzh/WrgKa6iGcHXLg==", + "dev": true + }, + "node_modules/picocolors": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/picocolors/-/picocolors-1.0.1.tgz", + "integrity": "sha512-anP1Z8qwhkbmu7MFP5iTt+wQKXgwzf7zTyGlcdzabySa9vd0Xt392U0rVmz9poOaBj0uHJKyyo9/upk0HrEQew==", + "dev": true + }, + "node_modules/pify": { + "version": "4.0.1", + "resolved": "https://registry.npmjs.org/pify/-/pify-4.0.1.tgz", + "integrity": "sha512-uB80kBFb/tfd68bVleG9T5GGsGPjJrLAUpR5PZIrhBnIaRTQRjqdJSsIKkOP6OAIFbj7GOrcudc5pNjZ+geV2g==", + "dev": true, + "engines": { + "node": ">=6" + } + }, + "node_modules/pkg-conf": { + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/pkg-conf/-/pkg-conf-3.1.0.tgz", + "integrity": "sha512-m0OTbR/5VPNPqO1ph6Fqbj7Hv6QU7gR/tQW40ZqrL1rjgCU85W6C1bJn0BItuJqnR98PWzw7Z8hHeChD1WrgdQ==", + "dev": true, + "dependencies": { + "find-up": "^3.0.0", + "load-json-file": "^5.2.0" + }, + "engines": { + "node": ">=6" + } + }, + "node_modules/pkg-conf/node_modules/find-up": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/find-up/-/find-up-3.0.0.tgz", + "integrity": "sha512-1yD6RmLI1XBfxugvORwlck6f75tYL+iR0jqwsOrOxMZyGYqUuDhJ0l4AXdO1iX/FTs9cBAMEk1gWSEx1kSbylg==", + "dev": true, + "dependencies": { + "locate-path": "^3.0.0" + }, + "engines": { + "node": ">=6" + } + }, + "node_modules/pkg-conf/node_modules/locate-path": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-3.0.0.tgz", + "integrity": "sha512-7AO748wWnIhNqAuaty2ZWHkQHRSNfPVIsPIfwEOWO22AmaoVrWavlOcMR5nzTLNYvp36X220/maaRsrec1G65A==", + "dev": true, + "dependencies": { + "p-locate": "^3.0.0", + "path-exists": "^3.0.0" + }, + "engines": { + "node": ">=6" + } + }, + "node_modules/pkg-conf/node_modules/p-locate": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-3.0.0.tgz", + "integrity": "sha512-x+12w/To+4GFfgJhBEpiDcLozRJGegY+Ei7/z0tSLkMmxGZNybVMSfWj9aJn8Z5Fc7dBUNJOOVgPv2H7IwulSQ==", + "dev": true, + "dependencies": { + "p-limit": "^2.0.0" + }, + "engines": { + "node": ">=6" + } + }, + "node_modules/pkg-conf/node_modules/path-exists": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/path-exists/-/path-exists-3.0.0.tgz", + "integrity": "sha512-bpC7GYwiDYQ4wYLe+FA8lhRjhQCMcQGuSgGGqDkg/QerRWw9CmGRT0iSOVRSZJ29NMLZgIzqaljJ63oaL4NIJQ==", + "dev": true, + "engines": { + "node": ">=4" + } + }, + "node_modules/pkg-dir": { + "version": "4.2.0", + "resolved": "https://registry.npmjs.org/pkg-dir/-/pkg-dir-4.2.0.tgz", + "integrity": "sha512-HRDzbaKjC+AOWVXxAU/x54COGeIv9eb+6CkDSQoNTt4XyWoIJvuPsXizxu/Fr23EiekbtZwmh1IcIG/l/a10GQ==", + "dev": true, + "dependencies": { + "find-up": "^4.0.0" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/possible-typed-array-names": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/possible-typed-array-names/-/possible-typed-array-names-1.0.0.tgz", + "integrity": "sha512-d7Uw+eZoloe0EHDIYoe+bQ5WXnGMOpmiZFTuMWCwpjzzkL2nTjcKiAk4hh8TjnGye2TwWOk3UXucZ+3rbmBa8Q==", + "dev": true, + "engines": { + "node": ">= 0.4" + } + }, + "node_modules/prelude-ls": { + "version": "1.2.1", + "resolved": "https://registry.npmjs.org/prelude-ls/-/prelude-ls-1.2.1.tgz", + "integrity": "sha512-vkcDPrRZo1QZLbn5RLGPpg/WmIQ65qoWWhcGKf/b5eplkkarX0m9z8ppCat4mlOqUsWpyNuYgO3VRyrYHSzX5g==", + "dev": true, + "engines": { + "node": ">= 0.8.0" + } + }, + "node_modules/process-on-spawn": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/process-on-spawn/-/process-on-spawn-1.0.0.tgz", + "integrity": "sha512-1WsPDsUSMmZH5LeMLegqkPDrsGgsWwk1Exipy2hvB0o/F0ASzbpIctSCcZIK1ykJvtTJULEH+20WOFjMvGnCTg==", + "dev": true, + "dependencies": { + "fromentries": "^1.2.0" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/progress": { + "version": "2.0.3", + "resolved": "https://registry.npmjs.org/progress/-/progress-2.0.3.tgz", + "integrity": "sha512-7PiHtLll5LdnKIMw100I+8xJXR5gW2QwWYkT6iJva0bXitZKa/XMrSbdmg3r2Xnaidz9Qumd0VPaMrZlF9V9sA==", + "dev": true, + "engines": { + "node": ">=0.4.0" + } + }, + "node_modules/prop-types": { + "version": "15.8.1", + "resolved": "https://registry.npmjs.org/prop-types/-/prop-types-15.8.1.tgz", + "integrity": "sha512-oj87CgZICdulUohogVAR7AjlC0327U4el4L6eAvOqCeudMDVU0NThNaV+b9Df4dXgSP1gXMTnPdhfe/2qDH5cg==", + "dev": true, + "dependencies": { + "loose-envify": "^1.4.0", + "object-assign": "^4.1.1", + "react-is": "^16.13.1" + } + }, + "node_modules/proxy-from-env": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/proxy-from-env/-/proxy-from-env-1.1.0.tgz", + "integrity": "sha512-D+zkORCbA9f1tdWRK0RaCR3GPv50cMxcrz4X8k5LTSUD1Dkw47mKJEZQNunItRTkWwgtaUSo1RVFRIG9ZXiFYg==", + "dev": true + }, + "node_modules/pump": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/pump/-/pump-3.0.0.tgz", + "integrity": "sha512-LwZy+p3SFs1Pytd/jYct4wpv49HiYCqd9Rlc5ZVdk0V+8Yzv6jR5Blk3TRmPL1ft69TxP0IMZGJ+WPFU2BFhww==", + "dev": true, + "dependencies": { + "end-of-stream": "^1.1.0", + "once": "^1.3.1" + } + }, + "node_modules/punycode": { + "version": "2.3.1", + "resolved": "https://registry.npmjs.org/punycode/-/punycode-2.3.1.tgz", + "integrity": "sha512-vYt7UD1U9Wg6138shLtLOvdAu+8DsC/ilFtEVHcH+wydcSpNE20AfSOduf6MkRFahL5FY7X1oU7nKVZFtfq8Fg==", + "dev": true, + "engines": { + "node": ">=6" + } + }, + "node_modules/puppeteer": { + "version": "19.11.1", + "resolved": "https://registry.npmjs.org/puppeteer/-/puppeteer-19.11.1.tgz", + "integrity": "sha512-39olGaX2djYUdhaQQHDZ0T0GwEp+5f9UB9HmEP0qHfdQHIq0xGQZuAZ5TLnJIc/88SrPLpEflPC+xUqOTv3c5g==", + "deprecated": "< 22.8.2 is no longer supported", + "dev": true, + "hasInstallScript": true, + "dependencies": { + "@puppeteer/browsers": "0.5.0", + "cosmiconfig": "8.1.3", + "https-proxy-agent": "5.0.1", + "progress": "2.0.3", + "proxy-from-env": "1.1.0", + "puppeteer-core": "19.11.1" + } + }, + "node_modules/puppeteer-core": { + "version": "19.11.1", + "resolved": "https://registry.npmjs.org/puppeteer-core/-/puppeteer-core-19.11.1.tgz", + "integrity": "sha512-qcuC2Uf0Fwdj9wNtaTZ2OvYRraXpAK+puwwVW8ofOhOgLPZyz1c68tsorfIZyCUOpyBisjr+xByu7BMbEYMepA==", + "dev": true, + "dependencies": { + "@puppeteer/browsers": "0.5.0", + "chromium-bidi": "0.4.7", + "cross-fetch": "3.1.5", + "debug": "4.3.4", + "devtools-protocol": "0.0.1107588", + "extract-zip": "2.0.1", + "https-proxy-agent": "5.0.1", + "proxy-from-env": "1.1.0", + "tar-fs": "2.1.1", + "unbzip2-stream": "1.4.3", + "ws": "8.13.0" + }, + "engines": { + "node": ">=14.14.0" + }, + "peerDependencies": { + "typescript": ">= 4.7.4" + }, + "peerDependenciesMeta": { + "typescript": { + "optional": true + } + } + }, + "node_modules/puppeteer-core/node_modules/debug": { + "version": "4.3.4", + "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.4.tgz", + "integrity": "sha512-PRWFHuSU3eDtQJPvnNY7Jcket1j0t5OuOsFzPPzsekD52Zl8qUfFIPEiswXqIvHWGVHOgX+7G/vCNNhehwxfkQ==", + "dev": true, + "dependencies": { + "ms": "2.1.2" + }, + "engines": { + "node": ">=6.0" + }, + "peerDependenciesMeta": { + "supports-color": { + "optional": true + } + } + }, + "node_modules/queue-microtask": { + "version": "1.2.3", + "resolved": "https://registry.npmjs.org/queue-microtask/-/queue-microtask-1.2.3.tgz", + "integrity": "sha512-NuaNSa6flKT5JaSYQzJok04JzTL1CA6aGhv5rfLW3PgqA+M2ChpZQnAC8h8i4ZFkBS8X5RqkDBHA7r4hej3K9A==", + "dev": true, + "funding": [ + { + "type": "github", + "url": "https://github.com/sponsors/feross" + }, + { + "type": "patreon", + "url": "https://www.patreon.com/feross" + }, + { + "type": "consulting", + "url": "https://feross.org/support" + } + ] + }, + "node_modules/react-is": { + "version": "16.13.1", + "resolved": "https://registry.npmjs.org/react-is/-/react-is-16.13.1.tgz", + "integrity": "sha512-24e6ynE2H+OKt4kqsOvNd8kBpV65zoxbA4BVsEOB3ARVWQki/DHzaUoC5KuON/BiccDaCCTZBuOcfZs70kR8bQ==", + "dev": true + }, + "node_modules/readable-stream": { + "version": "3.6.2", + "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-3.6.2.tgz", + "integrity": "sha512-9u/sniCrY3D5WdsERHzHE4G2YCXqoG5FTHUiCC4SIbr6XcLZBY05ya9EKjYek9O5xOAwjGq+1JdGBAS7Q9ScoA==", + "dev": true, + "dependencies": { + "inherits": "^2.0.3", + "string_decoder": "^1.1.1", + "util-deprecate": "^1.0.1" + }, + "engines": { + "node": ">= 6" + } + }, + "node_modules/reflect.getprototypeof": { + "version": "1.0.6", + "resolved": "https://registry.npmjs.org/reflect.getprototypeof/-/reflect.getprototypeof-1.0.6.tgz", + "integrity": "sha512-fmfw4XgoDke3kdI6h4xcUz1dG8uaiv5q9gcEwLS4Pnth2kxT+GZ7YehS1JTMGBQmtV7Y4GFGbs2re2NqhdozUg==", + "dev": true, + "dependencies": { + "call-bind": "^1.0.7", + "define-properties": "^1.2.1", + "es-abstract": "^1.23.1", + "es-errors": "^1.3.0", + "get-intrinsic": "^1.2.4", + "globalthis": "^1.0.3", + "which-builtin-type": "^1.1.3" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/regenerator-runtime": { + "version": "0.14.1", + "resolved": "https://registry.npmjs.org/regenerator-runtime/-/regenerator-runtime-0.14.1.tgz", + "integrity": "sha512-dYnhHh0nJoMfnkZs6GmmhFknAGRrLznOu5nc9ML+EJxGvrx6H7teuevqVqCuPcPK//3eDrrjQhehXVx9cnkGdw==" + }, + "node_modules/regexp.prototype.flags": { + "version": "1.5.2", + "resolved": "https://registry.npmjs.org/regexp.prototype.flags/-/regexp.prototype.flags-1.5.2.tgz", + "integrity": "sha512-NcDiDkTLuPR+++OCKB0nWafEmhg/Da8aUPLPMQbK+bxKKCm1/S5he+AqYa4PlMCVBalb4/yxIRub6qkEx5yJbw==", + "dev": true, + "dependencies": { + "call-bind": "^1.0.6", + "define-properties": "^1.2.1", + "es-errors": "^1.3.0", + "set-function-name": "^2.0.1" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/regexpp": { + "version": "3.2.0", + "resolved": "https://registry.npmjs.org/regexpp/-/regexpp-3.2.0.tgz", + "integrity": "sha512-pq2bWo9mVD43nbts2wGv17XLiNLya+GklZ8kaDLV2Z08gDCsGpnKn9BFMepvWuHCbyVvY7J5o5+BVvoQbmlJLg==", + "dev": true, + "engines": { + "node": ">=8" + }, + "funding": { + "url": "https://github.com/sponsors/mysticatea" + } + }, + "node_modules/release-zalgo": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/release-zalgo/-/release-zalgo-1.0.0.tgz", + "integrity": "sha512-gUAyHVHPPC5wdqX/LG4LWtRYtgjxyX78oanFNTMMyFEfOqdC54s3eE82imuWKbOeqYht2CrNf64Qb8vgmmtZGA==", + "dev": true, + "dependencies": { + "es6-error": "^4.0.1" + }, + "engines": { + "node": ">=4" + } + }, + "node_modules/require-directory": { + "version": "2.1.1", + "resolved": "https://registry.npmjs.org/require-directory/-/require-directory-2.1.1.tgz", + "integrity": "sha512-fGxEI7+wsG9xrvdjsrlmL22OMTTiHRwAMroiEeMgq8gzoLC/PQr7RsRDSTLUg/bZAZtF+TVIkHc6/4RIKrui+Q==", + "dev": true, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/require-main-filename": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/require-main-filename/-/require-main-filename-2.0.0.tgz", + "integrity": "sha512-NKN5kMDylKuldxYLSUfrbo5Tuzh4hd+2E8NPPX02mZtn1VuREQToYe/ZdlJy+J3uCpfaiGF05e7B8W0iXbQHmg==", + "dev": true + }, + "node_modules/resolve": { + "version": "1.22.8", + "resolved": "https://registry.npmjs.org/resolve/-/resolve-1.22.8.tgz", + "integrity": "sha512-oKWePCxqpd6FlLvGV1VU0x7bkPmmCNolxzjMf4NczoDnQcIWrAF+cPtZn5i6n+RfD2d9i0tzpKnG6Yk168yIyw==", + "dev": true, + "dependencies": { + "is-core-module": "^2.13.0", + "path-parse": "^1.0.7", + "supports-preserve-symlinks-flag": "^1.0.0" + }, + "bin": { + "resolve": "bin/resolve" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/resolve-from": { + "version": "5.0.0", + "resolved": "https://registry.npmjs.org/resolve-from/-/resolve-from-5.0.0.tgz", + "integrity": "sha512-qYg9KP24dD5qka9J47d0aVky0N+b4fTU89LN9iDnjB5waksiC49rvMB0PrUJQGoTmH50XPiqOvAjDfaijGxYZw==", + "dev": true, + "engines": { + "node": ">=8" + } + }, + "node_modules/reusify": { + "version": "1.0.4", + "resolved": "https://registry.npmjs.org/reusify/-/reusify-1.0.4.tgz", + "integrity": "sha512-U9nH88a3fc/ekCF1l0/UP1IosiuIjyTh7hBvXVMHYgVcfGvt897Xguj2UOLDeI5BG2m7/uwyaLVT6fbtCwTyzw==", + "dev": true, + "engines": { + "iojs": ">=1.0.0", + "node": ">=0.10.0" + } + }, + "node_modules/rimraf": { + "version": "3.0.2", + "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-3.0.2.tgz", + "integrity": "sha512-JZkJMZkAGFFPP2YqXZXPbMlMBgsxzE8ILs4lMIX/2o0L9UBw9O/Y3o6wFw/i9YLapcUJWwqbi3kdxIPdC62TIA==", + "deprecated": "Rimraf versions prior to v4 are no longer supported", + "dev": true, + "dependencies": { + "glob": "^7.1.3" + }, + "bin": { + "rimraf": "bin.js" + }, + "funding": { + "url": "https://github.com/sponsors/isaacs" + } + }, + "node_modules/run-parallel": { + "version": "1.2.0", + "resolved": "https://registry.npmjs.org/run-parallel/-/run-parallel-1.2.0.tgz", + "integrity": "sha512-5l4VyZR86LZ/lDxZTR6jqL8AFE2S0IFLMP26AbjsLVADxHdhB/c0GUsH+y39UfCi3dzz8OlQuPmnaJOMoDHQBA==", + "dev": true, + "funding": [ + { + "type": "github", + "url": "https://github.com/sponsors/feross" + }, + { + "type": "patreon", + "url": "https://www.patreon.com/feross" + }, + { + "type": "consulting", + "url": "https://feross.org/support" + } + ], + "dependencies": { + "queue-microtask": "^1.2.2" + } + }, + "node_modules/safe-array-concat": { + "version": "1.1.2", + "resolved": "https://registry.npmjs.org/safe-array-concat/-/safe-array-concat-1.1.2.tgz", + "integrity": "sha512-vj6RsCsWBCf19jIeHEfkRMw8DPiBb+DMXklQ/1SGDHOMlHdPUkZXFQ2YdplS23zESTijAcurb1aSgJA3AgMu1Q==", + "dev": true, + "dependencies": { + "call-bind": "^1.0.7", + "get-intrinsic": "^1.2.4", + "has-symbols": "^1.0.3", + "isarray": "^2.0.5" + }, + "engines": { + "node": ">=0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/safe-buffer": { + "version": "5.2.1", + "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.2.1.tgz", + "integrity": "sha512-rp3So07KcdmmKbGvgaNxQSJr7bGVSVk5S9Eq1F+ppbRo70+YeaDxkw5Dd8NPN+GD6bjnYm2VuPuCXmpuYvmCXQ==", + "dev": true, + "funding": [ + { + "type": "github", + "url": "https://github.com/sponsors/feross" + }, + { + "type": "patreon", + "url": "https://www.patreon.com/feross" + }, + { + "type": "consulting", + "url": "https://feross.org/support" + } + ] + }, + "node_modules/safe-regex-test": { + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/safe-regex-test/-/safe-regex-test-1.0.3.tgz", + "integrity": "sha512-CdASjNJPvRa7roO6Ra/gLYBTzYzzPyyBXxIMdGW3USQLyjWEls2RgW5UBTXaQVp+OrpeCK3bLem8smtmheoRuw==", + "dev": true, + "dependencies": { + "call-bind": "^1.0.6", + "es-errors": "^1.3.0", + "is-regex": "^1.1.4" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/semver": { + "version": "6.3.1", + "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.1.tgz", + "integrity": "sha512-BR7VvDCVHO+q2xBEWskxS6DJE1qRnb7DxzUrogb71CWoSficBxYsiAGd+Kl0mmq/MprG9yArRkyrQxTO6XjMzA==", + "dev": true, + "bin": { + "semver": "bin/semver.js" + } + }, + "node_modules/set-blocking": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/set-blocking/-/set-blocking-2.0.0.tgz", + "integrity": "sha512-KiKBS8AnWGEyLzofFfmvKwpdPzqiy16LvQfK3yv/fVH7Bj13/wl3JSR1J+rfgRE9q7xUJK4qvgS8raSOeLUehw==", + "dev": true + }, + "node_modules/set-function-length": { + "version": "1.2.2", + "resolved": "https://registry.npmjs.org/set-function-length/-/set-function-length-1.2.2.tgz", + "integrity": "sha512-pgRc4hJ4/sNjWCSS9AmnS40x3bNMDTknHgL5UaMBTMyJnU90EgWh1Rz+MC9eFu4BuN/UwZjKQuY/1v3rM7HMfg==", + "dev": true, + "dependencies": { + "define-data-property": "^1.1.4", + "es-errors": "^1.3.0", + "function-bind": "^1.1.2", + "get-intrinsic": "^1.2.4", + "gopd": "^1.0.1", + "has-property-descriptors": "^1.0.2" + }, + "engines": { + "node": ">= 0.4" + } + }, + "node_modules/set-function-name": { + "version": "2.0.2", + "resolved": "https://registry.npmjs.org/set-function-name/-/set-function-name-2.0.2.tgz", + "integrity": "sha512-7PGFlmtwsEADb0WYyvCMa1t+yke6daIG4Wirafur5kcf+MhUnPms1UeR0CKQdTZD81yESwMHbtn+TR+dMviakQ==", + "dev": true, + "dependencies": { + "define-data-property": "^1.1.4", + "es-errors": "^1.3.0", + "functions-have-names": "^1.2.3", + "has-property-descriptors": "^1.0.2" + }, + "engines": { + "node": ">= 0.4" + } + }, + "node_modules/shebang-command": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/shebang-command/-/shebang-command-2.0.0.tgz", + "integrity": "sha512-kHxr2zZpYtdmrN1qDjrrX/Z1rR1kG8Dx+gkpK1G4eXmvXswmcE1hTWBWYUzlraYw1/yZp6YuDY77YtvbN0dmDA==", + "dev": true, + "dependencies": { + "shebang-regex": "^3.0.0" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/shebang-regex": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/shebang-regex/-/shebang-regex-3.0.0.tgz", + "integrity": "sha512-7++dFhtcx3353uBaq8DDR4NuxBetBzC7ZQOhmTQInHEd6bSrXdiEyzCvG07Z44UYdLShWUyXt5M/yhz8ekcb1A==", + "dev": true, + "engines": { + "node": ">=8" + } + }, + "node_modules/side-channel": { + "version": "1.0.6", + "resolved": "https://registry.npmjs.org/side-channel/-/side-channel-1.0.6.tgz", + "integrity": "sha512-fDW/EZ6Q9RiO8eFG8Hj+7u/oW+XrPTIChwCOM2+th2A6OblDtYYIpve9m+KvI9Z4C9qSEXlaGR6bTEYHReuglA==", + "dev": true, + "dependencies": { + "call-bind": "^1.0.7", + "es-errors": "^1.3.0", + "get-intrinsic": "^1.2.4", + "object-inspect": "^1.13.1" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/signal-exit": { + "version": "3.0.7", + "resolved": "https://registry.npmjs.org/signal-exit/-/signal-exit-3.0.7.tgz", + "integrity": "sha512-wnD2ZE+l+SPC/uoS0vXeE9L1+0wuaMqKlfz9AMUo38JsyLSBWSFcHR1Rri62LZc12vLr1gb3jl7iwQhgwpAbGQ==", + "dev": true + }, + "node_modules/source-map": { + "version": "0.6.1", + "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.6.1.tgz", + "integrity": "sha512-UjgapumWlbMhkBgzT7Ykc5YXUT46F0iKu8SGXq0bcwP5dz/h0Plj6enJqjz1Zbq2l5WaqYnrVbwWOWMyF3F47g==", + "dev": true, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/spawn-wrap": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/spawn-wrap/-/spawn-wrap-2.0.0.tgz", + "integrity": "sha512-EeajNjfN9zMnULLwhZZQU3GWBoFNkbngTUPfaawT4RkMiviTxcX0qfhVbGey39mfctfDHkWtuecgQ8NJcyQWHg==", + "dev": true, + "dependencies": { + "foreground-child": "^2.0.0", + "is-windows": "^1.0.2", + "make-dir": "^3.0.0", + "rimraf": "^3.0.0", + "signal-exit": "^3.0.2", + "which": "^2.0.1" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/sprintf-js": { + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/sprintf-js/-/sprintf-js-1.0.3.tgz", + "integrity": "sha512-D9cPgkvLlV3t3IzL0D0YLvGA9Ahk4PcvVwUbN0dSGr1aP0Nrt4AEnTUbuGvquEC0mA64Gqt1fzirlRs5ibXx8g==", + "dev": true + }, + "node_modules/standard": { + "version": "17.1.0", + "resolved": "https://registry.npmjs.org/standard/-/standard-17.1.0.tgz", + "integrity": "sha512-jaDqlNSzLtWYW4lvQmU0EnxWMUGQiwHasZl5ZEIwx3S/ijZDjZOzs1y1QqKwKs5vqnFpGtizo4NOYX2s0Voq/g==", + "dev": true, + "funding": [ + { + "type": "github", + "url": "https://github.com/sponsors/feross" + }, + { + "type": "patreon", + "url": "https://www.patreon.com/feross" + }, + { + "type": "consulting", + "url": "https://feross.org/support" + } + ], + "dependencies": { + "eslint": "^8.41.0", + "eslint-config-standard": "17.1.0", + "eslint-config-standard-jsx": "^11.0.0", + "eslint-plugin-import": "^2.27.5", + "eslint-plugin-n": "^15.7.0", + "eslint-plugin-promise": "^6.1.1", + "eslint-plugin-react": "^7.32.2", + "standard-engine": "^15.0.0", + "version-guard": "^1.1.1" + }, + "bin": { + "standard": "bin/cmd.cjs" + }, + "engines": { + "node": "^12.22.0 || ^14.17.0 || >=16.0.0" + } + }, + "node_modules/standard-engine": { + "version": "15.1.0", + "resolved": "https://registry.npmjs.org/standard-engine/-/standard-engine-15.1.0.tgz", + "integrity": "sha512-VHysfoyxFu/ukT+9v49d4BRXIokFRZuH3z1VRxzFArZdjSCFpro6rEIU3ji7e4AoAtuSfKBkiOmsrDqKW5ZSRw==", + "dev": true, + "funding": [ + { + "type": "github", + "url": "https://github.com/sponsors/feross" + }, + { + "type": "patreon", + "url": "https://www.patreon.com/feross" + }, + { + "type": "consulting", + "url": "https://feross.org/support" + } + ], + "dependencies": { + "get-stdin": "^8.0.0", + "minimist": "^1.2.6", + "pkg-conf": "^3.1.0", + "xdg-basedir": "^4.0.0" + }, + "engines": { + "node": "^12.22.0 || ^14.17.0 || >=16.0.0" + } + }, + "node_modules/string_decoder": { + "version": "1.3.0", + "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-1.3.0.tgz", + "integrity": "sha512-hkRX8U1WjJFd8LsDJ2yQ/wWWxaopEsABU1XfkM8A+j0+85JAGppt16cr1Whg6KIbb4okU6Mql6BOj+uup/wKeA==", + "dev": true, + "dependencies": { + "safe-buffer": "~5.2.0" + } + }, + "node_modules/string-width": { + "version": "4.2.3", + "resolved": "https://registry.npmjs.org/string-width/-/string-width-4.2.3.tgz", + "integrity": "sha512-wKyQRQpjJ0sIp62ErSZdGsjMJWsap5oRNihHhu6G7JVO/9jIB6UyevL+tXuOqrng8j/cxKTWyWUwvSTriiZz/g==", + "dev": true, + "dependencies": { + "emoji-regex": "^8.0.0", + "is-fullwidth-code-point": "^3.0.0", + "strip-ansi": "^6.0.1" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/string.prototype.matchall": { + "version": "4.0.11", + "resolved": "https://registry.npmjs.org/string.prototype.matchall/-/string.prototype.matchall-4.0.11.tgz", + "integrity": "sha512-NUdh0aDavY2og7IbBPenWqR9exH+E26Sv8e0/eTe1tltDGZL+GtBkDAnnyBtmekfK6/Dq3MkcGtzXFEd1LQrtg==", + "dev": true, + "dependencies": { + "call-bind": "^1.0.7", + "define-properties": "^1.2.1", + "es-abstract": "^1.23.2", + "es-errors": "^1.3.0", + "es-object-atoms": "^1.0.0", + "get-intrinsic": "^1.2.4", + "gopd": "^1.0.1", + "has-symbols": "^1.0.3", + "internal-slot": "^1.0.7", + "regexp.prototype.flags": "^1.5.2", + "set-function-name": "^2.0.2", + "side-channel": "^1.0.6" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/string.prototype.repeat": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/string.prototype.repeat/-/string.prototype.repeat-1.0.0.tgz", + "integrity": "sha512-0u/TldDbKD8bFCQ/4f5+mNRrXwZ8hg2w7ZR8wa16e8z9XpePWl3eGEcUD0OXpEH/VJH/2G3gjUtR3ZOiBe2S/w==", + "dev": true, + "dependencies": { + "define-properties": "^1.1.3", + "es-abstract": "^1.17.5" + } + }, + "node_modules/string.prototype.trim": { + "version": "1.2.9", + "resolved": "https://registry.npmjs.org/string.prototype.trim/-/string.prototype.trim-1.2.9.tgz", + "integrity": "sha512-klHuCNxiMZ8MlsOihJhJEBJAiMVqU3Z2nEXWfWnIqjN0gEFS9J9+IxKozWWtQGcgoa1WUZzLjKPTr4ZHNFTFxw==", + "dev": true, + "dependencies": { + "call-bind": "^1.0.7", + "define-properties": "^1.2.1", + "es-abstract": "^1.23.0", + "es-object-atoms": "^1.0.0" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/string.prototype.trimend": { + "version": "1.0.8", + "resolved": "https://registry.npmjs.org/string.prototype.trimend/-/string.prototype.trimend-1.0.8.tgz", + "integrity": "sha512-p73uL5VCHCO2BZZ6krwwQE3kCzM7NKmis8S//xEC6fQonchbum4eP6kR4DLEjQFO3Wnj3Fuo8NM0kOSjVdHjZQ==", + "dev": true, + "dependencies": { + "call-bind": "^1.0.7", + "define-properties": "^1.2.1", + "es-object-atoms": "^1.0.0" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/string.prototype.trimstart": { + "version": "1.0.8", + "resolved": "https://registry.npmjs.org/string.prototype.trimstart/-/string.prototype.trimstart-1.0.8.tgz", + "integrity": "sha512-UXSH262CSZY1tfu3G3Secr6uGLCFVPMhIqHjlgCUtCCcgihYc/xKs9djMTMUOb2j1mVSeU8EU6NWc/iQKU6Gfg==", + "dev": true, + "dependencies": { + "call-bind": "^1.0.7", + "define-properties": "^1.2.1", + "es-object-atoms": "^1.0.0" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/strip-ansi": { + "version": "6.0.1", + "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.1.tgz", + "integrity": "sha512-Y38VPSHcqkFrCpFnQ9vuSXmquuv5oXOKpGeT6aGrr3o3Gc9AlVa6JBfUSOCnbxGGZF+/0ooI7KrPuUSztUdU5A==", + "dev": true, + "dependencies": { + "ansi-regex": "^5.0.1" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/strip-bom": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/strip-bom/-/strip-bom-4.0.0.tgz", + "integrity": "sha512-3xurFv5tEgii33Zi8Jtp55wEIILR9eh34FAW00PZf+JnSsTmV/ioewSgQl97JHvgjoRGwPShsWm+IdrxB35d0w==", + "dev": true, + "engines": { + "node": ">=8" + } + }, + "node_modules/strip-json-comments": { + "version": "3.1.1", + "resolved": "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-3.1.1.tgz", + "integrity": "sha512-6fPc+R4ihwqP6N/aIv2f1gMH8lOVtWQHoqC4yK6oSDVVocumAsfCqjkXnqiYMhmMwS/mEHLp7Vehlt3ql6lEig==", + "dev": true, + "engines": { + "node": ">=8" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/supports-color": { + "version": "5.5.0", + "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-5.5.0.tgz", + "integrity": "sha512-QjVjwdXIt408MIiAqCX4oUKsgU2EqAGzs2Ppkm4aQYbjm+ZEWEcW4SfFNTr4uMNZma0ey4f5lgLrkB0aX0QMow==", + "dev": true, + "dependencies": { + "has-flag": "^3.0.0" + }, + "engines": { + "node": ">=4" + } + }, + "node_modules/supports-preserve-symlinks-flag": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/supports-preserve-symlinks-flag/-/supports-preserve-symlinks-flag-1.0.0.tgz", + "integrity": "sha512-ot0WnXS9fgdkgIcePe6RHNk1WA8+muPa6cSjeR3V8K27q9BB1rTE3R1p7Hv0z1ZyAc8s6Vvv8DIyWf681MAt0w==", + "dev": true, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/tar-fs": { + "version": "2.1.1", + "resolved": "https://registry.npmjs.org/tar-fs/-/tar-fs-2.1.1.tgz", + "integrity": "sha512-V0r2Y9scmbDRLCNex/+hYzvp/zyYjvFbHPNgVTKfQvVrb6guiE/fxP+XblDNR011utopbkex2nM4dHNV6GDsng==", + "dev": true, + "dependencies": { + "chownr": "^1.1.1", + "mkdirp-classic": "^0.5.2", + "pump": "^3.0.0", + "tar-stream": "^2.1.4" + } + }, + "node_modules/tar-stream": { + "version": "2.2.0", + "resolved": "https://registry.npmjs.org/tar-stream/-/tar-stream-2.2.0.tgz", + "integrity": "sha512-ujeqbceABgwMZxEJnk2HDY2DlnUZ+9oEcb1KzTVfYHio0UE6dG71n60d8D2I4qNvleWrrXpmjpt7vZeF1LnMZQ==", + "dev": true, + "dependencies": { + "bl": "^4.0.3", + "end-of-stream": "^1.4.1", + "fs-constants": "^1.0.0", + "inherits": "^2.0.3", + "readable-stream": "^3.1.1" + }, + "engines": { + "node": ">=6" + } + }, + "node_modules/test-exclude": { + "version": "6.0.0", + "resolved": "https://registry.npmjs.org/test-exclude/-/test-exclude-6.0.0.tgz", + "integrity": "sha512-cAGWPIyOHU6zlmg88jwm7VRyXnMN7iV68OGAbYDk/Mh/xC/pzVPlQtY6ngoIH/5/tciuhGfvESU8GrHrcxD56w==", + "dev": true, + "dependencies": { + "@istanbuljs/schema": "^0.1.2", + "glob": "^7.1.4", + "minimatch": "^3.0.4" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/text-table": { + "version": "0.2.0", + "resolved": "https://registry.npmjs.org/text-table/-/text-table-0.2.0.tgz", + "integrity": "sha512-N+8UisAXDGk8PFXP4HAzVR9nbfmVJ3zYLAWiTIoqC5v5isinhr+r5uaO8+7r3BMfuNIufIsA7RdpVgacC2cSpw==", + "dev": true + }, + "node_modules/through": { + "version": "2.3.8", + "resolved": "https://registry.npmjs.org/through/-/through-2.3.8.tgz", + "integrity": "sha512-w89qg7PI8wAdvX60bMDP+bFoD5Dvhm9oLheFp5O4a2QF0cSBGsBX4qZmadPMvVqlLJBBci+WqGGOAPvcDeNSVg==", + "dev": true + }, + "node_modules/to-fast-properties": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/to-fast-properties/-/to-fast-properties-2.0.0.tgz", + "integrity": "sha512-/OaKK0xYrs3DmxRYqL/yDc+FxFUVYhDlXMhRmv3z915w2HF1tnN1omB354j8VUGO/hbRzyD6Y3sA7v7GS/ceog==", + "dev": true, + "engines": { + "node": ">=4" + } + }, + "node_modules/tr46": { + "version": "0.0.3", + "resolved": "https://registry.npmjs.org/tr46/-/tr46-0.0.3.tgz", + "integrity": "sha512-N3WMsuqV66lT30CrXNbEjx4GEwlow3v6rr4mCcv6prnfwhS01rkgyFdjPNBYd9br7LpXV1+Emh01fHnq2Gdgrw==", + "dev": true + }, + "node_modules/tsconfig-paths": { + "version": "3.15.0", + "resolved": "https://registry.npmjs.org/tsconfig-paths/-/tsconfig-paths-3.15.0.tgz", + "integrity": "sha512-2Ac2RgzDe/cn48GvOe3M+o82pEFewD3UPbyoUHHdKasHwJKjds4fLXWf/Ux5kATBKN20oaFGu+jbElp1pos0mg==", + "dev": true, + "dependencies": { + "@types/json5": "^0.0.29", + "json5": "^1.0.2", + "minimist": "^1.2.6", + "strip-bom": "^3.0.0" + } + }, + "node_modules/tsconfig-paths/node_modules/json5": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/json5/-/json5-1.0.2.tgz", + "integrity": "sha512-g1MWMLBiz8FKi1e4w0UyVL3w+iJceWAFBAaBnnGKOpNa5f8TLktkbre1+s6oICydWAm+HRUGTmI+//xv2hvXYA==", + "dev": true, + "dependencies": { + "minimist": "^1.2.0" + }, + "bin": { + "json5": "lib/cli.js" + } + }, + "node_modules/tsconfig-paths/node_modules/strip-bom": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/strip-bom/-/strip-bom-3.0.0.tgz", + "integrity": "sha512-vavAMRXOgBVNF6nyEEmL3DBK19iRpDcoIwW+swQ+CbGiu7lju6t+JklA1MHweoWtadgt4ISVUsXLyDq34ddcwA==", + "dev": true, + "engines": { + "node": ">=4" + } + }, + "node_modules/type-check": { + "version": "0.4.0", + "resolved": "https://registry.npmjs.org/type-check/-/type-check-0.4.0.tgz", + "integrity": "sha512-XleUoc9uwGXqjWwXaUTZAmzMcFZ5858QA2vvx1Ur5xIcixXIP+8LnFDgRplU30us6teqdlskFfu+ae4K79Ooew==", + "dev": true, + "dependencies": { + "prelude-ls": "^1.2.1" + }, + "engines": { + "node": ">= 0.8.0" + } + }, + "node_modules/type-detect": { + "version": "4.1.0", + "resolved": "https://registry.npmjs.org/type-detect/-/type-detect-4.1.0.tgz", + "integrity": "sha512-Acylog8/luQ8L7il+geoSxhEkazvkslg7PSNKOX59mbB9cOveP5aq9h74Y7YU8yDpJwetzQQrfIwtf4Wp4LKcw==", + "dev": true, + "engines": { + "node": ">=4" + } + }, + "node_modules/type-fest": { + "version": "0.8.1", + "resolved": "https://registry.npmjs.org/type-fest/-/type-fest-0.8.1.tgz", + "integrity": "sha512-4dbzIzqvjtgiM5rw1k5rEHtBANKmdudhGyBEajN01fEyhaAIhsoKNy6y7+IN93IfpFtwY9iqi7kD+xwKhQsNJA==", + "dev": true, + "engines": { + "node": ">=8" + } + }, + "node_modules/typed-array-buffer": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/typed-array-buffer/-/typed-array-buffer-1.0.2.tgz", + "integrity": "sha512-gEymJYKZtKXzzBzM4jqa9w6Q1Jjm7x2d+sh19AdsD4wqnMPDYyvwpsIc2Q/835kHuo3BEQ7CjelGhfTsoBb2MQ==", + "dev": true, + "dependencies": { + "call-bind": "^1.0.7", + "es-errors": "^1.3.0", + "is-typed-array": "^1.1.13" + }, + "engines": { + "node": ">= 0.4" + } + }, + "node_modules/typed-array-byte-length": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/typed-array-byte-length/-/typed-array-byte-length-1.0.1.tgz", + "integrity": "sha512-3iMJ9q0ao7WE9tWcaYKIptkNBuOIcZCCT0d4MRvuuH88fEoEH62IuQe0OtraD3ebQEoTRk8XCBoknUNc1Y67pw==", + "dev": true, + "dependencies": { + "call-bind": "^1.0.7", + "for-each": "^0.3.3", + "gopd": "^1.0.1", + "has-proto": "^1.0.3", + "is-typed-array": "^1.1.13" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/typed-array-byte-offset": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/typed-array-byte-offset/-/typed-array-byte-offset-1.0.2.tgz", + "integrity": "sha512-Ous0vodHa56FviZucS2E63zkgtgrACj7omjwd/8lTEMEPFFyjfixMZ1ZXenpgCFBBt4EC1J2XsyVS2gkG0eTFA==", + "dev": true, + "dependencies": { + "available-typed-arrays": "^1.0.7", + "call-bind": "^1.0.7", + "for-each": "^0.3.3", + "gopd": "^1.0.1", + "has-proto": "^1.0.3", + "is-typed-array": "^1.1.13" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/typed-array-length": { + "version": "1.0.6", + "resolved": "https://registry.npmjs.org/typed-array-length/-/typed-array-length-1.0.6.tgz", + "integrity": "sha512-/OxDN6OtAk5KBpGb28T+HZc2M+ADtvRxXrKKbUwtsLgdoxgX13hyy7ek6bFRl5+aBs2yZzB0c4CnQfAtVypW/g==", + "dev": true, + "dependencies": { + "call-bind": "^1.0.7", + "for-each": "^0.3.3", + "gopd": "^1.0.1", + "has-proto": "^1.0.3", + "is-typed-array": "^1.1.13", + "possible-typed-array-names": "^1.0.0" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/typedarray-to-buffer": { + "version": "3.1.5", + "resolved": "https://registry.npmjs.org/typedarray-to-buffer/-/typedarray-to-buffer-3.1.5.tgz", + "integrity": "sha512-zdu8XMNEDepKKR+XYOXAVPtWui0ly0NtohUscw+UmaHiAWT8hrV1rr//H6V+0DvJ3OQ19S979M0laLfX8rm82Q==", + "dev": true, + "dependencies": { + "is-typedarray": "^1.0.0" + } + }, + "node_modules/unbox-primitive": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/unbox-primitive/-/unbox-primitive-1.0.2.tgz", + "integrity": "sha512-61pPlCD9h51VoreyJ0BReideM3MDKMKnh6+V9L08331ipq6Q8OFXZYiqP6n/tbHx4s5I9uRhcye6BrbkizkBDw==", + "dev": true, + "dependencies": { + "call-bind": "^1.0.2", + "has-bigints": "^1.0.2", + "has-symbols": "^1.0.3", + "which-boxed-primitive": "^1.0.2" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/unbzip2-stream": { + "version": "1.4.3", + "resolved": "https://registry.npmjs.org/unbzip2-stream/-/unbzip2-stream-1.4.3.tgz", + "integrity": "sha512-mlExGW4w71ebDJviH16lQLtZS32VKqsSfk80GCfUlwT/4/hNRFsoscrF/c++9xinkMzECL1uL9DDwXqFWkruPg==", + "dev": true, + "dependencies": { + "buffer": "^5.2.1", + "through": "^2.3.8" + } + }, + "node_modules/undici-types": { + "version": "6.19.8", + "resolved": "https://registry.npmjs.org/undici-types/-/undici-types-6.19.8.tgz", + "integrity": "sha512-ve2KP6f/JnbPBFyobGHuerC9g1FYGn/F8n1LWTwNxCEzd6IfqTwUQcNXgEtmmQ6DlRrC1hrSrBnCZPokRrDHjw==", + "dev": true, + "optional": true + }, + "node_modules/update-browserslist-db": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/update-browserslist-db/-/update-browserslist-db-1.1.0.tgz", + "integrity": "sha512-EdRAaAyk2cUE1wOf2DkEhzxqOQvFOoRJFNS6NeyJ01Gp2beMRpBAINjM2iDXE3KCuKhwnvHIQCJm6ThL2Z+HzQ==", + "dev": true, + "funding": [ + { + "type": "opencollective", + "url": "https://opencollective.com/browserslist" + }, + { + "type": "tidelift", + "url": "https://tidelift.com/funding/github/npm/browserslist" + }, + { + "type": "github", + "url": "https://github.com/sponsors/ai" + } + ], + "dependencies": { + "escalade": "^3.1.2", + "picocolors": "^1.0.1" + }, + "bin": { + "update-browserslist-db": "cli.js" + }, + "peerDependencies": { + "browserslist": ">= 4.21.0" + } + }, + "node_modules/uri-js": { + "version": "4.4.1", + "resolved": "https://registry.npmjs.org/uri-js/-/uri-js-4.4.1.tgz", + "integrity": "sha512-7rKUyy33Q1yc98pQ1DAmLtwX109F7TIfWlW1Ydo8Wl1ii1SeHieeh0HHfPeL2fMXK6z0s8ecKs9frCuLJvndBg==", + "dev": true, + "dependencies": { + "punycode": "^2.1.0" + } + }, + "node_modules/util-deprecate": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/util-deprecate/-/util-deprecate-1.0.2.tgz", + "integrity": "sha512-EPD5q1uXyFxJpCrLnCc1nHnq3gOa6DZBocAIiI2TaSCA7VCJ1UJDMagCzIkXNsUYfD1daK//LTEQ8xiIbrHtcw==", + "dev": true + }, + "node_modules/uuid": { + "version": "8.3.2", + "resolved": "https://registry.npmjs.org/uuid/-/uuid-8.3.2.tgz", + "integrity": "sha512-+NYs2QeMWy+GWFOEm9xnn6HCDp0l7QBD7ml8zLUmJ+93Q5NF0NocErnwkTkXVFNiX3/fpC6afS8Dhb/gz7R7eg==", + "dev": true, + "bin": { + "uuid": "dist/bin/uuid" + } + }, + "node_modules/version-guard": { + "version": "1.1.2", + "resolved": "https://registry.npmjs.org/version-guard/-/version-guard-1.1.2.tgz", + "integrity": "sha512-D8d+YxCUpoqtCnQzDxm6SF7DLU3gr2535T4khAtMq4osBahsQnmSxuwXFdrbAdDGG8Uokzfis/jvyeFPdmlc7w==", + "dev": true, + "engines": { + "node": ">=0.10.48" + } + }, + "node_modules/webidl-conversions": { + "version": "3.0.1", + "resolved": "https://registry.npmjs.org/webidl-conversions/-/webidl-conversions-3.0.1.tgz", + "integrity": "sha512-2JAn3z8AR6rjK8Sm8orRC0h/bcl/DqL7tRPdGZ4I1CjdF+EaMLmYxBHyXuKL849eucPFhvBoxMsflfOb8kxaeQ==", + "dev": true + }, + "node_modules/whatwg-url": { + "version": "5.0.0", + "resolved": "https://registry.npmjs.org/whatwg-url/-/whatwg-url-5.0.0.tgz", + "integrity": "sha512-saE57nupxk6v3HY35+jzBwYa0rKSy0XR8JSxZPwgLr7ys0IBzhGviA1/TUGJLmSVqs8pb9AnvICXEuOHLprYTw==", + "dev": true, + "dependencies": { + "tr46": "~0.0.3", + "webidl-conversions": "^3.0.0" + } + }, + "node_modules/which": { + "version": "2.0.2", + "resolved": "https://registry.npmjs.org/which/-/which-2.0.2.tgz", + "integrity": "sha512-BLI3Tl1TW3Pvl70l3yq3Y64i+awpwXqsGBYWkkqMtnbXgrMD+yj7rhW0kuEDxzJaYXGjEW5ogapKNMEKNMjibA==", + "dev": true, + "dependencies": { + "isexe": "^2.0.0" + }, + "bin": { + "node-which": "bin/node-which" + }, + "engines": { + "node": ">= 8" + } + }, + "node_modules/which-boxed-primitive": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/which-boxed-primitive/-/which-boxed-primitive-1.0.2.tgz", + "integrity": "sha512-bwZdv0AKLpplFY2KZRX6TvyuN7ojjr7lwkg6ml0roIy9YeuSr7JS372qlNW18UQYzgYK9ziGcerWqZOmEn9VNg==", + "dev": true, + "dependencies": { + "is-bigint": "^1.0.1", + "is-boolean-object": "^1.1.0", + "is-number-object": "^1.0.4", + "is-string": "^1.0.5", + "is-symbol": "^1.0.3" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/which-builtin-type": { + "version": "1.1.4", + "resolved": "https://registry.npmjs.org/which-builtin-type/-/which-builtin-type-1.1.4.tgz", + "integrity": "sha512-bppkmBSsHFmIMSl8BO9TbsyzsvGjVoppt8xUiGzwiu/bhDCGxnpOKCxgqj6GuyHE0mINMDecBFPlOm2hzY084w==", + "dev": true, + "dependencies": { + "function.prototype.name": "^1.1.6", + "has-tostringtag": "^1.0.2", + "is-async-function": "^2.0.0", + "is-date-object": "^1.0.5", + "is-finalizationregistry": "^1.0.2", + "is-generator-function": "^1.0.10", + "is-regex": "^1.1.4", + "is-weakref": "^1.0.2", + "isarray": "^2.0.5", + "which-boxed-primitive": "^1.0.2", + "which-collection": "^1.0.2", + "which-typed-array": "^1.1.15" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/which-collection": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/which-collection/-/which-collection-1.0.2.tgz", + "integrity": "sha512-K4jVyjnBdgvc86Y6BkaLZEN933SwYOuBFkdmBu9ZfkcAbdVbpITnDmjvZ/aQjRXQrv5EPkTnD1s39GiiqbngCw==", + "dev": true, + "dependencies": { + "is-map": "^2.0.3", + "is-set": "^2.0.3", + "is-weakmap": "^2.0.2", + "is-weakset": "^2.0.3" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/which-module": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/which-module/-/which-module-2.0.1.tgz", + "integrity": "sha512-iBdZ57RDvnOR9AGBhML2vFZf7h8vmBjhoaZqODJBFWHVtKkDmKuHai3cx5PgVMrX5YDNp27AofYbAwctSS+vhQ==", + "dev": true + }, + "node_modules/which-typed-array": { + "version": "1.1.15", + "resolved": "https://registry.npmjs.org/which-typed-array/-/which-typed-array-1.1.15.tgz", + "integrity": "sha512-oV0jmFtUky6CXfkqehVvBP/LSWJ2sy4vWMioiENyJLePrBO/yKyV9OyJySfAKosh+RYkIl5zJCNZ8/4JncrpdA==", + "dev": true, + "dependencies": { + "available-typed-arrays": "^1.0.7", + "call-bind": "^1.0.7", + "for-each": "^0.3.3", + "gopd": "^1.0.1", + "has-tostringtag": "^1.0.2" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/word-wrap": { + "version": "1.2.5", + "resolved": "https://registry.npmjs.org/word-wrap/-/word-wrap-1.2.5.tgz", + "integrity": "sha512-BN22B5eaMMI9UMtjrGd5g5eCYPpCPDUy0FJXbYsaT5zYxjFOckS53SQDE3pWkVoWpHXVb3BrYcEN4Twa55B5cA==", + "dev": true, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/wrap-ansi": { + "version": "6.2.0", + "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-6.2.0.tgz", + "integrity": "sha512-r6lPcBGxZXlIcymEu7InxDMhdW0KDxpLgoFLcguasxCaJ/SOIZwINatK9KY/tf+ZrlywOKU0UDj3ATXUBfxJXA==", + "dev": true, + "dependencies": { + "ansi-styles": "^4.0.0", + "string-width": "^4.1.0", + "strip-ansi": "^6.0.0" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/wrap-ansi/node_modules/ansi-styles": { + "version": "4.3.0", + "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", + "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", + "dev": true, + "dependencies": { + "color-convert": "^2.0.1" + }, + "engines": { + "node": ">=8" + }, + "funding": { + "url": "https://github.com/chalk/ansi-styles?sponsor=1" + } + }, + "node_modules/wrap-ansi/node_modules/color-convert": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", + "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", + "dev": true, + "dependencies": { + "color-name": "~1.1.4" + }, + "engines": { + "node": ">=7.0.0" + } + }, + "node_modules/wrap-ansi/node_modules/color-name": { + "version": "1.1.4", + "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", + "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", + "dev": true + }, + "node_modules/wrappy": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz", + "integrity": "sha512-l4Sp/DRseor9wL6EvV2+TuQn63dMkPjZ/sp9XkghTEbV9KlPS1xUsZ3u7/IQO4wxtcFB4bgpQPRcR3QCvezPcQ==", + "dev": true + }, + "node_modules/write-file-atomic": { + "version": "3.0.3", + "resolved": "https://registry.npmjs.org/write-file-atomic/-/write-file-atomic-3.0.3.tgz", + "integrity": "sha512-AvHcyZ5JnSfq3ioSyjrBkH9yW4m7Ayk8/9My/DD9onKeu/94fwrMocemO2QAJFAlnnDN+ZDS+ZjAR5ua1/PV/Q==", + "dev": true, + "dependencies": { + "imurmurhash": "^0.1.4", + "is-typedarray": "^1.0.0", + "signal-exit": "^3.0.2", + "typedarray-to-buffer": "^3.1.5" + } + }, + "node_modules/ws": { + "version": "8.13.0", + "resolved": "https://registry.npmjs.org/ws/-/ws-8.13.0.tgz", + "integrity": "sha512-x9vcZYTrFPC7aSIbj7sRCYo7L/Xb8Iy+pW0ng0wt2vCJv7M9HOMy0UoN3rr+IFC7hb7vXoqS+P9ktyLLLhO+LA==", + "dev": true, + "engines": { + "node": ">=10.0.0" + }, + "peerDependencies": { + "bufferutil": "^4.0.1", + "utf-8-validate": ">=5.0.2" + }, + "peerDependenciesMeta": { + "bufferutil": { + "optional": true + }, + "utf-8-validate": { + "optional": true + } + } + }, + "node_modules/xdg-basedir": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/xdg-basedir/-/xdg-basedir-4.0.0.tgz", + "integrity": "sha512-PSNhEJDejZYV7h50BohL09Er9VaIefr2LMAf3OEmpCkjOi34eYyQYAXUTjEQtZJTKcF0E2UKTh+osDLsgNim9Q==", + "dev": true, + "engines": { + "node": ">=8" + } + }, + "node_modules/y18n": { + "version": "4.0.3", + "resolved": "https://registry.npmjs.org/y18n/-/y18n-4.0.3.tgz", + "integrity": "sha512-JKhqTOwSrqNA1NY5lSztJ1GrBiUodLMmIZuLiDaMRJ+itFd+ABVE8XBjOvIWL+rSqNDC74LCSFmlb/U4UZ4hJQ==", + "dev": true + }, + "node_modules/yallist": { + "version": "3.1.1", + "resolved": "https://registry.npmjs.org/yallist/-/yallist-3.1.1.tgz", + "integrity": "sha512-a4UGQaWPH59mOXUYnAG2ewncQS4i4F43Tv3JoAM+s2VDAmS9NsK8GpDMLrCHPksFT7h3K6TOoUNn2pb7RoXx4g==", + "dev": true + }, + "node_modules/yargs": { + "version": "15.4.1", + "resolved": "https://registry.npmjs.org/yargs/-/yargs-15.4.1.tgz", + "integrity": "sha512-aePbxDmcYW++PaqBsJ+HYUFwCdv4LVvdnhBy78E57PIor8/OVvhMrADFFEDh8DHDFRv/O9i3lPhsENjO7QX0+A==", + "dev": true, + "dependencies": { + "cliui": "^6.0.0", + "decamelize": "^1.2.0", + "find-up": "^4.1.0", + "get-caller-file": "^2.0.1", + "require-directory": "^2.1.1", + "require-main-filename": "^2.0.0", + "set-blocking": "^2.0.0", + "string-width": "^4.2.0", + "which-module": "^2.0.0", + "y18n": "^4.0.0", + "yargs-parser": "^18.1.2" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/yargs-parser": { + "version": "18.1.3", + "resolved": "https://registry.npmjs.org/yargs-parser/-/yargs-parser-18.1.3.tgz", + "integrity": "sha512-o50j0JeToy/4K6OZcaQmW6lyXXKhq7csREXcDwk2omFPJEwUNOVtJKvmDr9EI1fAJZUyZcRF7kxGBWmRXudrCQ==", + "dev": true, + "dependencies": { + "camelcase": "^5.0.0", + "decamelize": "^1.2.0" + }, + "engines": { + "node": ">=6" + } + }, + "node_modules/yauzl": { + "version": "2.10.0", + "resolved": "https://registry.npmjs.org/yauzl/-/yauzl-2.10.0.tgz", + "integrity": "sha512-p4a9I6X6nu6IhoGmBqAcbJy1mlC4j27vEPZX9F4L4/vZT3Lyq1VkFHw/V/PUcB9Buo+DG3iHkT0x3Qya58zc3g==", + "dev": true, + "dependencies": { + "buffer-crc32": "~0.2.3", + "fd-slicer": "~1.1.0" + } + }, + "node_modules/yocto-queue": { + "version": "0.1.0", + "resolved": "https://registry.npmjs.org/yocto-queue/-/yocto-queue-0.1.0.tgz", + "integrity": "sha512-rVksvsnNCdJ/ohGc6xgPwyN8eheCxsiLM8mxuE/t/mOVqJewPuO1miLpTHQiRgTKCLexL4MeAFVagts7HmNZ2Q==", + "dev": true, + "engines": { + "node": ">=10" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + } + } +} diff --git a/testapp3/package.json b/testapp3/package.json new file mode 100644 index 00000000..5c141e78 --- /dev/null +++ b/testapp3/package.json @@ -0,0 +1,42 @@ +{ + "name": "testapp3", + "private": true, + "scripts": { + "setup": "mkdir -p packages && ln -sfn ../../ ./packages/meteor-roles", + "test": "TEST_BROWSER_DRIVER=puppeteer meteor test-packages --raw-logs --once --driver-package meteortesting:mocha ./packages/meteor-roles", + "test:watch": "TEST_BROWSER_DRIVER=puppeteer TEST_WATCH=1 meteor test-packages --raw-logs --driver-package meteortesting:mocha ./packages/meteor-roles", + "test:coverage": "TEST_BROWSER_DRIVER=puppeteer TEST_CLIENT=1 TEST_SERVER=1 COVERAGE=1 COVERAGE_OUT_JSON=1 COVERAGE_OUT_HTML=1 COVERAGE_APP_FOLDER=$(pwd)/ meteor test-packages --raw-logs --once --driver-package meteortesting:mocha ./packages/meteor-roles", + "report": "nyc report -t .coverage", + "lint": "standard ../", + "lint:fix": "standard --fix ../" + }, + "dependencies": { + "@babel/runtime": "^7.25.6", + "meteor-node-stubs": "^1.2.9" + }, + "devDependencies": { + "babel-plugin-istanbul": "^6.1.1", + "chai": "^4.5.0", + "chai-as-promised": "^7.1.2", + "nyc": "^15.1.0", + "puppeteer": "^19.11.1", + "standard": "^17.1.0" + }, + "babel": { + "env": { + "COVERAGE": { + "plugins": [ + "istanbul" + ] + } + } + }, + "standard": { + "ignore": [ + "**/.meteor/", + "**/examples/", + "**/testapp2", + "**/testapp3" + ] + } +} From 82d6f651c719e4a90796184cd3166e137132684d Mon Sep 17 00:00:00 2001 From: Jan Dvorak Date: Sat, 31 Aug 2024 15:05:11 +0200 Subject: [PATCH 37/45] Fix lint test --- .github/workflows/testsuite.yml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.github/workflows/testsuite.yml b/.github/workflows/testsuite.yml index 460cd134..b6788961 100644 --- a/.github/workflows/testsuite.yml +++ b/.github/workflows/testsuite.yml @@ -27,7 +27,7 @@ jobs: restore-keys: | ${{ runner.os }}-node-20- - - run: cd testapp && npm ci && npm run setup && npm run lint + - run: cd testapp3 && npm ci && npm run setup && npm run lint test2: name: Meteor package tests 2.16 From 7a7e852c2ca933e11381a4ff449b1ecbe2979951 Mon Sep 17 00:00:00 2001 From: Jan Dvorak Date: Sat, 31 Aug 2024 15:14:32 +0200 Subject: [PATCH 38/45] Fixed fetch in tests --- roles/tests/serverAsync.js | 23 +++++++++++++++-------- 1 file changed, 15 insertions(+), 8 deletions(-) diff --git a/roles/tests/serverAsync.js b/roles/tests/serverAsync.js index 47c55cf2..df22a3ef 100644 --- a/roles/tests/serverAsync.js +++ b/roles/tests/serverAsync.js @@ -780,11 +780,13 @@ describe('roles async', async function () { // compare roles, sorted alphabetically const expected = roles - const actual = Roles.getAllRoles().fetch().map(r => r._id) + const fetchAll = await Roles.getAllRoles().fetchAsync() + const actual = fetchAll.map(r => r._id) assert.sameMembers(actual, expected) - assert.sameMembers(Roles.getAllRoles({ sort: { _id: -1 } }).fetch().map(r => r._id), expected.reverse()) + const fetchSorted = await Roles.getAllRoles({ sort: { _id: -1 } }).fetchAsync() + assert.sameMembers(fetchSorted.map(r => r._id), expected.reverse()) }) it('get an empty list of roles for an empty user', async function () { @@ -1231,7 +1233,8 @@ describe('roles async', async function () { const expected = [users.eve, users.joe] const cursor = await Roles.getUsersInRoleAsync('admin') - const actual = cursor.fetch().map(r => r._id) + const fetched = await cursor.fetchAsync() + const actual = fetched.map(r => r._id) assert.sameMembers(actual, expected) }) @@ -1245,22 +1248,26 @@ describe('roles async', async function () { let expected = [users.eve, users.joe] const cursor1 = await Roles.getUsersInRoleAsync('admin', 'scope1') - let actual = cursor1.fetch().map(r => r._id) + const fetched1 = await cursor1.fetchAsync() + let actual = fetched1.map(r => r._id) assert.sameMembers(actual, expected) expected = [users.eve, users.joe] const cursor2 = await Roles.getUsersInRoleAsync('admin', { scope: 'scope1' }) - actual = cursor2.fetch().map(r => r._id) + const fetched2 = await cursor2.fetchAsync() + actual = fetched2.map(r => r._id) assert.sameMembers(actual, expected) expected = [users.eve, users.bob, users.joe] const cursor3 = await Roles.getUsersInRoleAsync('admin', { anyScope: true }) - actual = cursor3.fetch().map(r => r._id) + const fetched3 = await cursor3.fetchAsync() + actual = fetched3.map(r => r._id) assert.sameMembers(actual, expected) const cursor4 = await Roles.getUsersInRoleAsync('admin') - actual = cursor4.fetch().map(r => r._id) + const fetched4 = await cursor4.fetchAsync() + actual = fetched4.map(r => r._id) assert.sameMembers(actual, []) }) @@ -1319,7 +1326,7 @@ describe('roles async', async function () { await Roles.addUsersToRolesAsync([users.bob, users.joe], ['admin'], 'scope2') const cursor = await Roles.getUsersInRoleAsync('admin', 'scope1', { fields: { username: 0 }, limit: 1 }) - const results = cursor.fetch() + const results = await cursor.fetchAsync() assert.equal(1, results.length) assert.isTrue(hasProp(results[0], '_id')) From ea42be891377656f676e61e10b473746048747f3 Mon Sep 17 00:00:00 2001 From: Jan Dvorak Date: Thu, 5 Sep 2024 11:09:13 +0200 Subject: [PATCH 39/45] Fix insert issue with async client tests --- roles/roles_client.js | 54 +++++++++++++++++++------------------- roles/tests/clientAsync.js | 5 ++-- roles/tests/serverAsync.js | 5 +++- 3 files changed, 34 insertions(+), 30 deletions(-) diff --git a/roles/roles_client.js b/roles/roles_client.js index bc04a237..7291d154 100644 --- a/roles/roles_client.js +++ b/roles/roles_client.js @@ -97,7 +97,7 @@ Object.assign(Roles, { // For all roles who have it as a dependency ... roles = Roles._getParentRoleNames(Meteor.roles.findOne({ _id: roleName })) - Meteor.roles.find({ _id: { $in: roles } }).fetch().forEach(r => { + for (const r of Meteor.roles.find({ _id: { $in: roles } }).fetch()) { Meteor.roles.update({ _id: r._id }, { @@ -116,7 +116,7 @@ Object.assign(Roles, { inheritedRoles: [r._id, ...inheritedRoles].map(r2 => ({ _id: r2 })) } }, { multi: true }) - }) + } } while (roles.length > 0) // And finally remove the role itself @@ -197,9 +197,9 @@ Object.assign(Roles, { // ensure arrays if (!Array.isArray(rolesNames)) rolesNames = [rolesNames] - rolesNames.forEach(function (roleName) { + for (const roleName of rolesNames) { Roles._addRoleToParent(roleName, parentName) - }) + } }, /** @@ -266,9 +266,9 @@ Object.assign(Roles, { // ensure arrays if (!Array.isArray(rolesNames)) rolesNames = [rolesNames] - rolesNames.forEach(function (roleName) { + for (const roleName of rolesNames) { Roles._removeRoleFromParent(roleName, parentName) - }) + } }, /** @@ -307,7 +307,7 @@ Object.assign(Roles, { // For all roles who have had it as a dependency ... const roles = [...Roles._getParentRoleNames(Meteor.roles.findOne({ _id: parentName })), parentName] - Meteor.roles.find({ _id: { $in: roles } }).fetch().forEach(r => { + for (const r of Meteor.roles.find({ _id: { $in: roles } }).fetch()) { const inheritedRoles = Roles._getInheritedRoleNames(Meteor.roles.findOne({ _id: r._id })) Meteor.roleAssignment.update({ 'role._id': r._id, @@ -317,7 +317,7 @@ Object.assign(Roles, { inheritedRoles: [r._id, ...inheritedRoles].map(r2 => ({ _id: r2 })) } }, { multi: true }) - }) + } }, /** @@ -359,17 +359,17 @@ Object.assign(Roles, { ifExists: false }, options) - users.forEach(function (user) { + for (const user of users) { if (typeof user === 'object') { id = user._id } else { id = user } - roles.forEach(function (role) { + for (const role of roles) { Roles._addUserToRole(id, role, options) - }) - }) + } + } }, /** @@ -413,7 +413,7 @@ Object.assign(Roles, { anyScope: false }, options) - users.forEach(function (user) { + for (const user of users) { if (typeof user === 'object') { id = user._id } else { @@ -428,10 +428,10 @@ Object.assign(Roles, { Meteor.roleAssignment.remove(selector) // and then add all - roles.forEach(function (role) { + for (const role of roles) { Roles._addUserToRole(id, role, options) - }) - }) + } + } }, /** @@ -506,11 +506,11 @@ Object.assign(Roles, { const parentRoles = new Set([role._id]) - parentRoles.forEach(roleName => { + for (const roleName of parentRoles) { Meteor.roles.find({ 'children._id': roleName }).fetch().forEach(parentRole => { parentRoles.add(parentRole._id) }) - }) + } parentRoles.delete(role._id) @@ -532,14 +532,14 @@ Object.assign(Roles, { const inheritedRoles = new Set() const nestedRoles = new Set([role]) - nestedRoles.forEach(r => { + for (const r of nestedRoles) { const roles = Meteor.roles.find({ _id: { $in: r.children.map(r => r._id) } }, { fields: { children: 1 } }).fetch() - roles.forEach(r2 => { + for (const r2 of roles) { inheritedRoles.add(r2._id) nestedRoles.add(r2) - }) - }) + } + } return [...inheritedRoles] }, @@ -574,10 +574,10 @@ Object.assign(Roles, { Roles._checkScopeName(options.scope) - users.forEach(function (user) { - if (!user) return + for (const user of users) { + if (!user) continue - roles.forEach(function (role) { + for (const role of roles) { let id if (typeof user === 'object') { id = user._id @@ -586,8 +586,8 @@ Object.assign(Roles, { } Roles._removeUserFromRole(id, role, options) - }) - }) + } + } }, /** diff --git a/roles/tests/clientAsync.js b/roles/tests/clientAsync.js index 4e00c78c..11d0b3f1 100644 --- a/roles/tests/clientAsync.js +++ b/roles/tests/clientAsync.js @@ -40,10 +40,11 @@ describe('roles async', function () { const msg = username + ' expected to have \'' + role + '\' permission but does not' const nmsg = username + ' had un-expected permission ' + role + const result = await Roles.userIsInRoleAsync(user, role, scope) if (expected) { - assert.isTrue(await Roles.userIsInRoleAsync(user, role, scope), msg) + assert.isTrue(result, msg) } else { - assert.isFalse(await Roles.userIsInRoleAsync(user, role, scope), nmsg) + assert.isFalse(result, nmsg) } } } diff --git a/roles/tests/serverAsync.js b/roles/tests/serverAsync.js index df22a3ef..35b069f2 100644 --- a/roles/tests/serverAsync.js +++ b/roles/tests/serverAsync.js @@ -13,8 +13,11 @@ chai.use(chaiAsPromised) // To allow inserting on the client, needed for testing. Meteor.roleAssignment.allow({ insert () { return true }, + insertAsync () { return true }, update () { return true }, - remove () { return true } + updateAsync () { return true }, + remove () { return true }, + removeAsync () { return true } }) const hasProp = (target, prop) => Object.hasOwnProperty.call(target, prop) From c46b2e62e784cc6ec76dd3a111b9a5331e578aa4 Mon Sep 17 00:00:00 2001 From: Jan Dvorak Date: Thu, 5 Sep 2024 11:41:44 +0200 Subject: [PATCH 40/45] Removed deprecated publication of legacy role assignments --- History.md | 1 + package.js | 3 +-- roles/client/subscriptions.js | 18 ------------------ roles/roles_client.js | 8 ++++++-- roles/roles_server.js | 20 -------------------- roles/tests/clientAsync.js | 2 +- 6 files changed, 9 insertions(+), 43 deletions(-) delete mode 100644 roles/client/subscriptions.js diff --git a/History.md b/History.md index e32c4458..d427489e 100644 --- a/History.md +++ b/History.md @@ -4,6 +4,7 @@ * BREAKING: Synchronous functions are now available only on client side * BREAKING: Migration functions for past versions are no longer available +* Removed deprecated publication of legacy role assignments * UI Helpers now use `console.debug` for debugging messages * `RolesCollection` and `RoleAssignmentsCollection` can now be exported in addition to being accessed via `Meteor.roles` and `Meteor.roleAssignment` * Support for Meteor 3 diff --git a/package.js b/package.js index 7615b7ec..3a09a2db 100644 --- a/package.js +++ b/package.js @@ -32,8 +32,7 @@ Package.onUse(function (api) { api.addFiles('roles/roles_server.js', 'server') api.addFiles([ 'roles/client/debug.js', - 'roles/client/uiHelpers.js', - 'roles/client/subscriptions.js' + 'roles/client/uiHelpers.js' ], 'client') }) diff --git a/roles/client/subscriptions.js b/roles/client/subscriptions.js deleted file mode 100644 index 76968fc3..00000000 --- a/roles/client/subscriptions.js +++ /dev/null @@ -1,18 +0,0 @@ -/* global Meteor, Roles, Tracker */ - -/** - * Subscription handle for the collection of all existing roles. - * - * @example - * - * Roles.subscription.ready(); // true if roles have been loaded - * - * @property subscription - * @type Object - * @for Roles - * @static - */ - -Tracker.autorun(function () { - Roles.subscription = Meteor.subscribe('_roles') -}) diff --git a/roles/roles_client.js b/roles/roles_client.js index 7291d154..e0ec9a7f 100644 --- a/roles/roles_client.js +++ b/roles/roles_client.js @@ -1091,8 +1091,12 @@ Object.assign(Roles, { _checkScopeName: function (scopeName) { if (scopeName === null) return - if (!scopeName || typeof scopeName !== 'string' || scopeName.trim() !== scopeName) { - throw new Error('Invalid scope name \'' + scopeName + '\'.') + if ( + !scopeName || + typeof scopeName !== 'string' || + scopeName.trim() !== scopeName + ) { + throw new Error(`Invalid scope name '${scopeName}'.`) } } }) diff --git a/roles/roles_server.js b/roles/roles_server.js index e06e2327..735dfd9b 100644 --- a/roles/roles_server.js +++ b/roles/roles_server.js @@ -15,23 +15,3 @@ for (const index of indexes) { indexFnAssignment(index) } indexFnRoles({ 'children._id': 1 }) - -/* - * Publish logged-in user's roles so client-side checks can work. - * - * Use a named publish function so clients can check `ready()` state. - */ -Meteor.publish('_roles', function () { - const loggedInUserId = this.userId - const fields = { roles: 1 } - - if (!loggedInUserId) { - this.ready() - return - } - - return Meteor.users.find( - { _id: loggedInUserId }, - { fields } - ) -}) diff --git a/roles/tests/clientAsync.js b/roles/tests/clientAsync.js index 11d0b3f1..ed365a8e 100644 --- a/roles/tests/clientAsync.js +++ b/roles/tests/clientAsync.js @@ -12,7 +12,7 @@ import '../roles_common_async' chai.use(chaiAsPromised) const safeInsert = async (collection, data) => { - try { + return await collection.insertAsync(data).catch(e => console.error(e)) await collection.insertAsync(data) } catch (e) {} } From 2a0fb72a66afd1ab9250eb1a31b52d67a2cbb065 Mon Sep 17 00:00:00 2001 From: Jan Dvorak Date: Thu, 5 Sep 2024 11:53:52 +0200 Subject: [PATCH 41/45] Fix async client tests Was missing subscription to get the data. Not sure why the sync client tests are able to still run. Maybe the data added persist in minimongo? --- roles/roles_server.js | 1 - roles/tests/clientAsync.js | 5 ++--- roles/tests/serverAsync.js | 5 +++++ 3 files changed, 7 insertions(+), 4 deletions(-) diff --git a/roles/roles_server.js b/roles/roles_server.js index 735dfd9b..e5059f8a 100644 --- a/roles/roles_server.js +++ b/roles/roles_server.js @@ -1,4 +1,3 @@ -import { Meteor } from 'meteor/meteor' import { RolesCollection, RoleAssignmentCollection } from './roles_common_async' const indexFnAssignment = RoleAssignmentCollection.createIndexAsync.bind(RoleAssignmentCollection) diff --git a/roles/tests/clientAsync.js b/roles/tests/clientAsync.js index ed365a8e..f1c28ee1 100644 --- a/roles/tests/clientAsync.js +++ b/roles/tests/clientAsync.js @@ -13,8 +13,6 @@ chai.use(chaiAsPromised) const safeInsert = async (collection, data) => { return await collection.insertAsync(data).catch(e => console.error(e)) - await collection.insertAsync(data) - } catch (e) {} } describe('roles async', function () { @@ -40,7 +38,7 @@ describe('roles async', function () { const msg = username + ' expected to have \'' + role + '\' permission but does not' const nmsg = username + ' had un-expected permission ' + role - const result = await Roles.userIsInRoleAsync(user, role, scope) + const result = await Roles.userIsInRoleAsync(user._id, role, scope) if (expected) { assert.isTrue(result, msg) } else { @@ -56,6 +54,7 @@ describe('roles async', function () { Meteor.user = function () { return users.eve } + Meteor.subscribe('client_assignments') }) after(() => { diff --git a/roles/tests/serverAsync.js b/roles/tests/serverAsync.js index 35b069f2..2e774ea2 100644 --- a/roles/tests/serverAsync.js +++ b/roles/tests/serverAsync.js @@ -10,6 +10,11 @@ import '../roles_common_async' chai.use(chaiAsPromised) +// Publication for the client tests +Meteor.publish('client_assignments', async () => { + return Meteor.roleAssignment.find() +}) + // To allow inserting on the client, needed for testing. Meteor.roleAssignment.allow({ insert () { return true }, From e0118338b0769d9161027aa4a2479ea7d8dce6b6 Mon Sep 17 00:00:00 2001 From: Jan Dvorak Date: Thu, 5 Sep 2024 12:37:02 +0200 Subject: [PATCH 42/45] Handle number in _normalizeOptions --- .gitignore | 2 ++ roles/roles_common_async.js | 4 +++- 2 files changed, 5 insertions(+), 1 deletion(-) diff --git a/.gitignore b/.gitignore index 936ee1e8..00e5ba2a 100644 --- a/.gitignore +++ b/.gitignore @@ -21,3 +21,5 @@ docs/ node_modules/ .npm/ .coverage/ + +examples/react-teams/.meteor/local/build/programs/server/node_modules diff --git a/roles/roles_common_async.js b/roles/roles_common_async.js index 45337feb..11079194 100644 --- a/roles/roles_common_async.js +++ b/roles/roles_common_async.js @@ -1277,7 +1277,9 @@ Object.assign(Roles, { _normalizeOptions: function (options) { options = options === undefined ? {} : options - if (options === null || typeof options === 'string') { + // TODO Number will error out on scope validation, we can either error it out here + // or make it into a string and hence a valid input. + if (options === null || typeof options === 'string' || typeof options === 'number') { options = { scope: options } } From e792f729fb58ca70e9ff7cfa3281fc6686b4983d Mon Sep 17 00:00:00 2001 From: Jan Dvorak Date: Thu, 5 Sep 2024 13:02:24 +0200 Subject: [PATCH 43/45] Fix backward compatibility for allow rules in tests --- roles/tests/serverAsync.js | 26 ++++++++++++++++++-------- 1 file changed, 18 insertions(+), 8 deletions(-) diff --git a/roles/tests/serverAsync.js b/roles/tests/serverAsync.js index 2e774ea2..f6efc59f 100644 --- a/roles/tests/serverAsync.js +++ b/roles/tests/serverAsync.js @@ -16,14 +16,24 @@ Meteor.publish('client_assignments', async () => { }) // To allow inserting on the client, needed for testing. -Meteor.roleAssignment.allow({ - insert () { return true }, - insertAsync () { return true }, - update () { return true }, - updateAsync () { return true }, - remove () { return true }, - removeAsync () { return true } -}) +if (Meteor.release.split('@')[1][1] === '2') { + Meteor.roleAssignment.allow({ + insert () { return true }, + update () { return true }, + remove () { return true } + }) +} else { + // Meteor 3+ + Meteor.roleAssignment.allow({ + insert () { return true }, + insertAsync () { return true }, + update () { return true }, + updateAsync () { return true }, + remove () { return true }, + removeAsync () { return true } + }) +} + const hasProp = (target, prop) => Object.hasOwnProperty.call(target, prop) From 5ac1f319625b8c02d76219499a46799d4b30cd06 Mon Sep 17 00:00:00 2001 From: Jan Dvorak Date: Thu, 5 Sep 2024 13:04:17 +0200 Subject: [PATCH 44/45] Quick lint fix --- roles/tests/serverAsync.js | 1 - 1 file changed, 1 deletion(-) diff --git a/roles/tests/serverAsync.js b/roles/tests/serverAsync.js index f6efc59f..b6b16452 100644 --- a/roles/tests/serverAsync.js +++ b/roles/tests/serverAsync.js @@ -34,7 +34,6 @@ if (Meteor.release.split('@')[1][1] === '2') { }) } - const hasProp = (target, prop) => Object.hasOwnProperty.call(target, prop) describe('roles async', async function () { From 02e54a95402719037e92e6e25a75bb582dceb565 Mon Sep 17 00:00:00 2001 From: Jan Dvorak Date: Thu, 5 Sep 2024 13:10:01 +0200 Subject: [PATCH 45/45] Fix typo in Meteor 2 test setup --- roles/tests/serverAsync.js | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/roles/tests/serverAsync.js b/roles/tests/serverAsync.js index b6b16452..278cab7e 100644 --- a/roles/tests/serverAsync.js +++ b/roles/tests/serverAsync.js @@ -16,7 +16,7 @@ Meteor.publish('client_assignments', async () => { }) // To allow inserting on the client, needed for testing. -if (Meteor.release.split('@')[1][1] === '2') { +if (Meteor.release.split('@')[1][0] === '2') { Meteor.roleAssignment.allow({ insert () { return true }, update () { return true },