@cubist-labs/cubesigner-sdk 0.4.204 → 0.4.205
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/package.json +1 -1
- package/dist/src/scopes.d.ts.map +1 -1
- package/dist/src/scopes.js +13 -3
- package/package.json +1 -1
- package/src/scopes.ts +14 -2
package/dist/package.json
CHANGED
|
@@ -5,7 +5,7 @@
|
|
|
5
5
|
"url": "git+https://github.com/cubist-labs/CubeSigner-TypeScript-SDK.git",
|
|
6
6
|
"directory": "packages/sdk"
|
|
7
7
|
},
|
|
8
|
-
"version": "0.4.
|
|
8
|
+
"version": "0.4.205",
|
|
9
9
|
"description": "CubeSigner TypeScript SDK",
|
|
10
10
|
"license": "MIT OR Apache-2.0",
|
|
11
11
|
"author": "Cubist, Inc.",
|
package/dist/src/scopes.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"scopes.d.ts","sourceRoot":"","sources":["../../src/scopes.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,KAAK,aAAa,EAAE,MAAM,GAAG,CAAC;AAEvC,MAAM,MAAM,gBAAgB,GAAG,MAAM,CAAC,MAAM,EAAE;IAAE,KAAK,EAAE,MAAM,CAAC;IAAC,MAAM,EAAE,SAAS,EAAE,CAAA;CAAE,CAAC,CAAC;AAEtF,MAAM,WAAW,SAAS;IACxB,KAAK,EAAE,aAAa,CAAC;IACrB,WAAW,EAAE,MAAM,CAAC;IACpB,QAAQ,CAAC,EAAE,SAAS,EAAE,CAAC;CACxB;AAED,mDAAmD;AACnD,eAAO,MAAM,SAAS,EAAE,MAAM,CAAC,aAAa,EAAE,MAAM,CAqLnD,CAAC;
|
|
1
|
+
{"version":3,"file":"scopes.d.ts","sourceRoot":"","sources":["../../src/scopes.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,KAAK,aAAa,EAAE,MAAM,GAAG,CAAC;AAEvC,MAAM,MAAM,gBAAgB,GAAG,MAAM,CAAC,MAAM,EAAE;IAAE,KAAK,EAAE,MAAM,CAAC;IAAC,MAAM,EAAE,SAAS,EAAE,CAAA;CAAE,CAAC,CAAC;AAEtF,MAAM,WAAW,SAAS;IACxB,KAAK,EAAE,aAAa,CAAC;IACrB,WAAW,EAAE,MAAM,CAAC;IACpB,QAAQ,CAAC,EAAE,SAAS,EAAE,CAAC;CACxB;AAED,mDAAmD;AACnD,eAAO,MAAM,SAAS,EAAE,MAAM,CAAC,aAAa,EAAE,MAAM,CAqLnD,CAAC;AAyFF;;;;;;;;;;;;;;;;;;;;;;GAsBG;AACH,eAAO,MAAM,mBAAmB,EAAE,gBAA4C,CAAC;AAE/E;;;GAGG;AACH,eAAO,MAAM,oBAAoB;;eApTsB,MAAM;gBAAU,SAAS,EAAE;;;eAA3B,MAAM;gBAAU,SAAS,EAAE;;;;;;CA+UtD,CAAC;AAE7B;;;GAGG;AACH,eAAO,MAAM,oBAAoB;;eArVsB,MAAM;gBAAU,SAAS,EAAE;;;eAA3B,MAAM;gBAAU,SAAS,EAAE;;;eAA3B,MAAM;gBAAU,SAAS,EAAE;;CAyVjF,CAAC"}
|
package/dist/src/scopes.js
CHANGED
|
@@ -196,18 +196,28 @@ const CATEGORY_LABELS = {
|
|
|
196
196
|
/**
|
|
197
197
|
* Finds the parent scope for a given scope.
|
|
198
198
|
* A parent is a scope ending with '*' that is a prefix of the current scope.
|
|
199
|
+
* Returns the longest matching parent (closest ancestor), excluding the scope itself.
|
|
199
200
|
*
|
|
200
201
|
* @param scope The scope to find the parent for.
|
|
201
202
|
* @param allScopes The list of all scopes.
|
|
202
203
|
* @returns The parent scope or null if no parent is found.
|
|
203
204
|
*/
|
|
204
205
|
function findParent(scope, allScopes) {
|
|
206
|
+
let parent = null;
|
|
207
|
+
let maxLength = 0;
|
|
205
208
|
for (const candidate of allScopes) {
|
|
209
|
+
// Skip the scope itself
|
|
210
|
+
if (candidate === scope)
|
|
211
|
+
continue;
|
|
206
212
|
if (candidate.endsWith("*") && scope.startsWith(candidate.slice(0, -1))) {
|
|
207
|
-
|
|
213
|
+
// Prefer the longest matching parent (closest ancestor)
|
|
214
|
+
if (candidate.length > maxLength) {
|
|
215
|
+
parent = candidate;
|
|
216
|
+
maxLength = candidate.length;
|
|
217
|
+
}
|
|
208
218
|
}
|
|
209
219
|
}
|
|
210
|
-
return
|
|
220
|
+
return parent;
|
|
211
221
|
}
|
|
212
222
|
/**
|
|
213
223
|
* Computes the scopes dictionary from AllScopes.
|
|
@@ -319,4 +329,4 @@ exports.userScopesDictionary = {
|
|
|
319
329
|
sign: exports.allScopesDictionary.sign,
|
|
320
330
|
mmi: exports.allScopesDictionary.mmi,
|
|
321
331
|
};
|
|
322
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"scopes.js","sourceRoot":"","sources":["../../src/scopes.ts"],"names":[],"mappings":"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","sourcesContent":["// eslint-disable spaced-comment\n\nimport { type ExplicitScope } from \".\";\n\nexport type ScopesDictionary = Record<string, { label: string; scopes: ScopeItem[] }>;\n\nexport interface ScopeItem {\n  value: ExplicitScope;\n  description: string;\n  children?: ScopeItem[];\n}\n\n/** Mapping from scope name to scope description */\nexport const AllScopes: Record<ExplicitScope, string> =\n  // prettier-ignore\n  {\n  \"sign:*\"                                      : \"Allows access to all signer endpoints (e.g., sign blob, sign bitcoin/avalanche/evm transaction, etc.)\",\n  \"sign:ava\"                                    : \"Allows access to the sign 'ava' endpoint\",\n  \"sign:blob\"                                   : \"Allows access to the sign 'blob' endpoint\",\n  \"sign:diffieHellman\"                          : \"Allows access to the Diffie-Hellman endpoint. This is not really signing, but we put it under the `sign` hierarchy because it is conceptually similar.\",\n  \"sign:btc:*\"                                  : \"Allows access to all BTC endpoints\",\n  \"sign:btc:segwit\"                             : \"Allows access to the signing endpoint for segwit transactions\",\n  \"sign:btc:taproot\"                            : \"Allows access to the signing endpoint for taproot transactions\",\n  \"sign:btc:psbt:*\"                             : \"Allows access to the PSBT signing endpoint for any key type\",\n  \"sign:btc:psbt:doge\"                          : \"Allows access to the PSBT signing endpoint for Doge keys\",\n  \"sign:btc:psbt:legacy\"                        : \"Allows access to the PSBT signing endpoint for legacy keys\",\n  \"sign:btc:psbt:segwit\"                        : \"Allows access to the PSBT signing endpoint for segwit keys\",\n  \"sign:btc:psbt:taproot\"                       : \"Allows access to the PSBT signing endpoint for taproot keys\",\n  \"sign:btc:psbt:ltcSegwit\"                     : \"Allows access to the PSBT signing endpoint for Litecoin segwit keys\",\n  \"sign:btc:message:*\"                          : \"Allows access to the BTC message signing endpoint for any key type\",\n  \"sign:btc:message:segwit\"                     : \"Allows access to the BTC message signing endpoint for segwit keys\",\n  \"sign:btc:message:legacy\"                     : \"Allows access to the BTC message signing endpoint for legacy keys\",\n  \"sign:babylon:*\"                              : \"Allows access to all Babylon endpoints\",\n  \"sign:babylon:eots:*\"                         : \"Allows access to all Babylon EOTS endpoints\",\n  \"sign:babylon:eots:nonces\"                    : \"Allows access to the EOTS nonce generation endpoint\",\n  \"sign:babylon:eots:sign\"                      : \"Allows access to the EOTS signing endpoint\",\n  \"sign:babylon:staking:*\"                      : \"Allows access to the signing endpoint for all Babylon staking operations\",\n  \"sign:babylon:staking:deposit\"                : \"Allows access to the signing endpoint for Babylon deposits\",\n  \"sign:babylon:staking:unbond\"                 : \"Allows access to the signing endpoint for Babylon unbonding\",\n  \"sign:babylon:staking:withdraw\"               : \"Allows access to the signing endpoint for Babylon withdrawals\",\n  \"sign:babylon:staking:slash\"                  : \"Allows access to the signing endpoint for Babylon slashing pre-signatures\",\n  \"sign:babylon:registration\"                   : \"Allows access to the signing endpoint for Babylon registration\",\n  \"sign:babylon:covenant\"                       : \"Allows access to the signing endpoint for Babylon covenant signing\",\n  \"sign:evm:*\"                                  : \"Allows access to all sign 'evm' endpoints\",\n  \"sign:evm:tx\"                                 : \"Allows access to the signing endpoint for evm transactions\",\n  \"sign:evm:eip191\"                             : \"Allows access to the signing endpoint for EIP-191 personal_message data\",\n  \"sign:evm:eip712\"                             : \"Allows acess to the signing endpoint for EIP-712 typed data\",\n  \"sign:eth2:*\"                                 : \"Allows access to all sign 'eth2' endpoints\",\n  \"sign:eth2:validate\"                          : \"Allows access to the sign eth2 'validate' endpoint\",\n  \"sign:eth2:stake\"                             : \"Allows access to the sign eth2 'stake' endpoint\",\n  \"sign:eth2:unstake\"                           : \"Allows access to the sign eth2 'unstake' endpoint\",\n  \"sign:solana\"                                 : \"Allows access to the sign 'solana' endpoint\",\n  \"sign:sui\"                                    : \"Allows access to the sign 'sui' endpoint\",\n  \"sign:tendermint\"                             : \"Allows access to the sign 'tendermint' endpoint\",\n  \"sign:mmi\"                                    : \"Allows access to the sign 'mmi' endpoint\",\n  \"manage:*\"                                    : \"Allows access to all management endpoints (e.g., create role, create key, add key to role, etc.)\",\n  \"manage:readonly\"                             : \"Allows access to all management readonly endpoints\",\n  \"manage:email\"                                : \"Allows access only to the email management endpoints\",\n  \"manage:mfa:*\"                                : \"Allows access only to MFA endpoints (e.g., get/approve existing MFA request)\",\n  \"manage:mfa:readonly\"                         : \"Allows access only to MFA readonly endpoints (e.g., get/list existing MFA request(s))\",\n  \"manage:mfa:list\"                             : \"Allows access only to the MFA list endpoint (list existing MFA requests)\",\n  \"manage:mfa:vote:*\"                           : \"Allows access to all MFA vote endpoints (vote using current CubeSigner session, TOTP, or FIDO)\",\n  \"manage:mfa:vote:cs\"                          : \"Allows access only to the MFA 'vote with CubeSigner' endpoint\",\n  \"manage:mfa:vote:email\"                       : \"Allows access only to the MFA 'vote with email' endpoint\",\n  \"manage:mfa:vote:fido\"                        : \"Allows access only to the MFA 'vote with TOTP' endpoint\",\n  \"manage:mfa:vote:totp\"                        : \"Allows access only to the MFA 'vote with FIDO' endpoint\",\n  \"manage:mfa:register:*\"                       : \"Allows access to all MFA register endpoints\",\n  \"manage:mfa:register:fido\"                    : \"Allows access only to the MFA 'register TOTP' endpoint\",\n  \"manage:mfa:register:totp\"                    : \"Allows access only to the MFA 'register FIDO' endpoint\",\n  \"manage:mfa:register:email\"                   : \"Allows access only to the MFA 'register verified email' endpoint\",\n  \"manage:mfa:unregister:*\"                     : \"Allows access to all MFA unregister endpoints\",\n  \"manage:mfa:unregister:fido\"                  : \"Allows access only to the MFA 'delete TOTP' endpoint\",\n  \"manage:mfa:unregister:totp\"                  : \"Allows access only to the MFA 'delete FIDO' endpoint\",\n  \"manage:mfa:verify:*\"                         : \"Allows access to all MFA verify endpoints\",\n  \"manage:mfa:verify:totp\"                      : \"Allows access only to the MFA 'verify TOTP' endpoint\",\n  \"manage:key:*\"                                : \"Allows access to all key endpoints\",\n  \"manage:key:readonly\"                         : \"Allows access to all key readonly endpoints\",\n  \"manage:key:attest\"                           : \"Allows access only to the key 'attest' endpoint\",\n  \"manage:key:get\"                              : \"Allows access only to the key 'get' endpoint\",\n  \"manage:key:listRoles\"                        : \"Allows access only to the key 'listRoles' endpoint\",\n  \"manage:key:list\"                             : \"Allows access only to the key 'list' endpoint\",\n  \"manage:key:history:tx:list\"                  : \"Allows access only to the key 'list_historical_tx' endpoint\",\n  \"manage:key:create\"                           : \"Allows access only to key creation endpoints (e.g., 'create' and 'derive')\",\n  \"manage:key:import\"                           : \"Allows access only to the key 'import' endpoint\",\n  \"manage:key:update:*\"                         : \"Allows access only to the key 'update' endpoint, within which allowing all possible updates\",\n  \"manage:key:update:owner\"                     : \"Allows access only to the key 'update' endpoint, but restricting updates to the key owner property\",\n  \"manage:key:update:policy\"                    : \"Allows access only to the key 'update' endpoint, but restricting updates to the key policy property\",\n  \"manage:key:update:enabled\"                   : \"Allows access only to the key 'update' endpoint, but restricting updates to the key enabled property\",\n  \"manage:key:update:metadata\"                  : \"Allows access only to the key 'update' endpoint and restricts updates to the key metadata property\",\n  \"manage:key:update:editPolicy\"                : \"Allows access only to the key 'update' endpoint and restricts updates to the 'edit_policy' property\",\n  \"manage:key:delete\"                           : \"Allows access only to the key 'delete' endpoint\",\n  \"manage:policy:*\"                             : \"Allows access to all policy endpoints\",\n  \"manage:policy:create\"                        : \"Allows access only to the policy creation endpoint\",\n  \"manage:policy:get\"                           : \"Allows access only to the policy 'get' endpoint\",\n  \"manage:policy:list\"                          : \"Allows access only to the policy 'list' endpoint\",\n  \"manage:policy:delete\"                        : \"Allows access only to the policy `delete` endpoint\",\n  \"manage:policy:update:*\"                      : \"Allows access only to the policy 'update' endpoint, within which allowing all possible updates\",\n  \"manage:policy:update:acl\"                    : \"Allows access only to the policy 'update' endpoint, but restricting updates to the policy ACL\",\n  \"manage:policy:update:owner\"                  : \"Allows access only to the policy 'update' endpoint, but restricting updates to the policy owner property\",\n  \"manage:policy:update:name\"                   : \"Allows access only to the policy 'update' endpoint, but restricting updates to the policy name\",\n  \"manage:policy:update:editPolicy\"             : \"Allows access only to the policy 'update' endpoint, but restricting updates to the 'edit_policy' property\",\n  \"manage:policy:update:metadata\"               : \"Allows access only to the policy 'update' endpoint, but restricting updates to the 'metadata' property\",\n  \"manage:policy:update:rule\"                   : \"Allows access only to the policy 'update' endpoint, but restricting updates to the policy rule itself\",\n  \"manage:policy:invoke\"                        : \"Allows access only to the policy 'invoke' endpoint.\",\n  \"manage:policy:wasm:*\"                        : \"Allows access to all wasm policy endpoints\",\n  \"manage:policy:wasm:upload\"                   : \"Allows access only to the wasm policy 'upload' endpoint\",\n  \"manage:policy:secrets:*\"                     : \"Allows access to all policy secrets endpoints\",\n  \"manage:policy:secrets:get\"                   : \"Allows access only to the policy secrets 'get' endpoint\",\n  \"manage:policy:secrets:update:*\"              : \"Allows access to all policy secrets 'update' endpoints\",\n  \"manage:policy:secrets:update:values\"         : \"Allows access only to the policy secrets 'update' endpoint, but restricting updates to the secrets keys and values\",\n  \"manage:policy:secrets:update:editPolicy\"     : \"Allows access only to the policy secrets 'update' endpoint, but restricting updates to the `edit_policy` property\",\n  \"manage:contact:*\"                            : \"Allows access to all contact endpoints\",\n  \"manage:contact:create\"                       : \"Allows access to the contact 'create' endpoint\",\n  \"manage:contact:get\"                          : \"Allows access to the contact `get` endpoint\",\n  \"manage:contact:list\"                         : \"Allows access to the contact `list` endpoint\",\n  \"manage:contact:delete\"                       : \"Allows access to the contact `delete` endpoint\",\n  \"manage:contact:update:*\"                     : \"Allows access only to the contact 'update' endpoint\",\n  \"manage:contact:update:name\"                  : \"Allows access only to the contact 'update' endpoint, but restricts updates to the contact's 'name' field.\",\n  \"manage:contact:update:addresses\"             : \"Allows access only to the contact 'update' endpoint, but restricts updates to the contact's 'addresses' field.\",\n  \"manage:contact:update:owner\"                 : \"Allows access only to the contact 'update' endpoint, but restricts updates to the contact's 'owner' field.\",\n  \"manage:contact:update:metadata\"              : \"Allows access only to the contact 'update' endpoint, but restricts updates to the contact's 'metadata' field.\",\n  \"manage:contact:update:editPolicy\"            : \"Allows access only to the contact 'update' endpoint, but restricts updates to the contact's 'edit_policy' field.\",\n  \"manage:contact:lookup:*\"                     : \"Allows access to the contact `lookup` endpoints\",\n  \"manage:contact:lookup:address\"               : \"Allows access only to the contact 'lookup by address' endpoint\",\n  \"manage:policy:createImportKey\"               : \"Allows access only to the policy key endpoint\",\n  \"manage:role:*\"                               : \"Allows access to all role endpoints\",\n  \"manage:role:readonly\"                        : \"Allows access to all role readonly endpoints\",\n  \"manage:role:create\"                          : \"Allows access only to the role 'create' endpoint\",\n  \"manage:role:delete\"                          : \"Allows access only to the role 'delete' endpoint\",\n  \"manage:role:get:*\"                           : \"Allows access only to the role 'get' endpoint\",\n  \"manage:role:get:keys\"                        : \"Allows access to the role 'list keys' and 'get key' endpoints\",\n  \"manage:role:get:keys:list\"                   : \"Allows access to the role 'list keys' endpoint\",\n  \"manage:role:get:keys:get\"                    : \"Allows access to the role 'get key' endpoint\",\n  \"manage:role:get:users\"                       : \"Allows access to the role 'list users' endpoint\",\n  \"manage:role:list\"                            : \"Allows access only to the role 'list' endpoint\",\n  \"manage:role:update:*\"                        : \"Allows access only to the role 'update' endpoint\",\n  \"manage:role:update:enabled\"                  : \"Allows access only to the role 'update' endpoint, but restricting updates to the role 'enabled' property\",\n  \"manage:role:update:policy\"                   : \"Allows access only to the role 'update' endpoint, but restricting updates to the role 'policy' property\",\n  \"manage:role:update:editPolicy\"               : \"Allows access only to the role 'update' endpoint, but restricting updates to the role 'edit_policy' property\",\n  \"manage:role:update:key:*\"                    : \"Allows access to all role 'update:key' endpoints\",\n  \"manage:role:update:key:add\"                  : \"Allows access to the role 'update:keys:add' endpoint\",\n  \"manage:role:update:key:remove\"               : \"Allows access to the role 'update:keys:remove' endpoint\",\n  \"manage:role:update:user:*\"                   : \"Allows access to all role 'update:user' endpoints\",\n  \"manage:role:update:user:add\"                 : \"Allows access to the role 'update:user:add' endpoint\",\n  \"manage:role:update:user:remove\"              : \"Allows access to the role 'update:user:remove' endpoint\",\n  \"manage:role:history:tx:list\"                 : \"Allows access only to the role 'list_historical_tx' endpoint\",\n  \"manage:identity:*\"                           : \"Allows access to all identity endpoints\",\n  \"manage:identity:verify\"                      : \"Allows access only to the identity 'verify' endpoint\",\n  \"manage:identity:add\"                         : \"Allows access only to the identity 'add' endpoint\",\n  \"manage:identity:remove\"                      : \"Allows access only to the identity 'remove' endpoint\",\n  \"manage:identity:list\"                        : \"Allows access only to the identity 'list' endpoint\",\n  \"manage:org:*\"                                : \"Allows access to all org endpoints\",\n  \"manage:org:create\"                           : \"Allows access to the org 'create' endpoint\",\n  \"manage:org:metrics:query\"                    : \"Allows access to retrieving org metrics\",\n  \"manage:org:readonly\"                         : \"Allows access to all org readonly endpoints\",\n  \"manage:org:addUser\"                          : \"Allows access only to the org endpoint for adding an OIDC user to the org\",\n  \"manage:org:inviteUser\"                       : \"Allows access only to the org endpoint for inviting a new member or org owner to the org\",\n  \"manage:org:inviteAlien\"                      : \"Allows access only to the org endpoint for inviting a new alien user to the org\",\n  \"manage:org:updateMembership\"                 : \"Allows access only to the org endpoint for updating existing user's org membership\",\n  \"manage:org:listUsers\"                        : \"Allows access only to the org endpoint for listing all org users (members)\",\n  \"manage:org:user:get\"                         : \"Allows access only to the org endpoints for getting users by id or email\",\n  \"manage:org:deleteUser\"                       : \"Allows access only to the org endpoint for deleting an OIDC user\",\n  \"manage:org:get\"                              : \"Allows access to retrieving organization information\",\n  \"manage:org:user:resetMfa\"                    : \"Allows an owner to initiate an MFA reset for a user\",\n  \"manage:session:*\"                            : \"Allows access to all session endpoints\",\n  \"manage:session:readonly\"                     : \"Allows access to all session readonly endpoints\",\n  \"manage:session:get\"                          : \"Allows access only to the session 'get' endpoint\",\n  \"manage:session:list\"                         : \"Allows access only to the session 'list' endpoint\",\n  \"manage:session:create\"                       : \"Allows access only to the session 'create' endpoint, but without the ability to extend session lifetimes\",\n  \"manage:session:extend\"                       : \"Allows access only to the session 'create' endpoint, including the ability to extend session lifetimes\",\n  \"manage:session:revoke\"                       : \"Allows access only to the session 'revoke' endpoints\",\n  \"manage:export:*\"                             : \"Allows access to all export endpoints\",\n  \"manage:export:org:*\"                         : \"Allows access to all org-export management endpoints\",\n  \"manage:export:org:get\"                       : \"Allows access to the org-export download endpoint\",\n  \"manage:export:user:*\"                        : \"Allows access to all user-export management endpoints\",\n  \"manage:export:user:delete\"                   : \"Allows deleting an existing user-export request\",\n  \"manage:export:user:list\"                     : \"Allows listing existing user-export requests\",\n  \"manage:authMigration:*\"                      : \"Allows all auth migration scopes\",\n  \"manage:authMigration:identity:add\"           : \"Allows adding identities to existing users during an auth migration\",\n  \"manage:authMigration:identity:remove\"        : \"Allows removing identities from existing users during an auth migration\",\n  \"manage:authMigration:user:update\"            : \"Allows updating existing users' profiles\",\n  \"manage:mmi:*\"                                : \"Allows all CRUD operations on MMI pending messages\",\n  \"manage:mmi:readonly\"                         : \"Allows all readonly operations on MMI pending messages\",\n  \"manage:mmi:get\"                              : \"Allows retrieving MMI pending messages\",\n  \"manage:mmi:list\"                             : \"Allows listing MMI pending messages\",\n  \"manage:mmi:reject\"                           : \"Allows rejecting MMI pending messages\",\n  \"manage:mmi:delete\"                           : \"Allows deleting MMI pending messages\",\n  \"export:*\"                                    : \"Allows access to all export endpoints\",\n  \"export:user:*\"                               : \"Allows access to all user-export execution endpoints\",\n  \"export:user:init\"                            : \"Allows initiating a new user-export request\",\n  \"export:user:complete\"                        : \"Allows completing an existing user-export request\",\n  \"mmi:*\"                                       : \"Allows calls to the MMI endpoint\",\n  \"orgAccess:*\"                                 : \"Allows access to certain orgs other than the current session's\",\n  \"orgAccess:child:*\"                           : \"Allows a session to be used for access to orgs transitively parented by the session's org.\",\n};\n\n// Const for scope category labels\nconst CATEGORY_LABELS: Record<string, string> = {\n  sign: \"Sign\",\n  manage: \"Manage\",\n  export: \"Export\",\n  mmi: \"MMI\",\n  orgAccess: \"Org Access\",\n};\n\n/**\n * Finds the parent scope for a given scope.\n * A parent is a scope ending with '*' that is a prefix of the current scope.\n *\n * @param scope The scope to find the parent for.\n * @param allScopes The list of all scopes.\n * @returns The parent scope or null if no parent is found.\n */\nfunction findParent(scope: ExplicitScope, allScopes: ExplicitScope[]): ExplicitScope | null {\n  for (const candidate of allScopes) {\n    if (candidate.endsWith(\"*\") && scope.startsWith(candidate.slice(0, -1))) {\n      return candidate;\n    }\n  }\n  return null;\n}\n\n/**\n * Computes the scopes dictionary from AllScopes.\n *\n * @returns The complete dictionary of all available scopes organized by category.\n */\nfunction computeScopesDictionary(): ScopesDictionary {\n  const allScopes = Object.keys(AllScopes) as ExplicitScope[];\n  const items = new Map<ExplicitScope, ScopeItem>();\n  const result: ScopesDictionary = {};\n\n  // First pass: create all items\n  for (const scope of allScopes) {\n    const category = scope.split(\":\")[0];\n    if (!result[category]) {\n      result[category] = { label: CATEGORY_LABELS[category] || category, scopes: [] };\n    }\n\n    items.set(scope, {\n      value: scope,\n      description: AllScopes[scope],\n      children: [],\n    });\n  }\n\n  // Second pass: build parent-child relationships\n  for (const scope of allScopes) {\n    const category = scope.split(\":\")[0];\n    const item = items.get(scope)!;\n    const parentScope = findParent(scope, allScopes);\n\n    if (parentScope && parentScope !== scope) {\n      items.get(parentScope)!.children!.push(item);\n    } else {\n      result[category].scopes.push(item);\n    }\n  }\n\n  // Sort roots: wildcards first\n  for (const category of Object.values(result)) {\n    category.scopes.sort((a, b) => {\n      if (a.value.endsWith(\"*\") && !b.value.endsWith(\"*\")) return -1;\n      if (!a.value.endsWith(\"*\") && b.value.endsWith(\"*\")) return 1;\n      return a.value.localeCompare(b.value);\n    });\n  }\n\n  return result;\n}\n\n/**\n * Complete dictionary of all available scopes organized by category.\n *\n * This dictionary is automatically computed from {@link AllScopes} by inferring\n * the hierarchy from scope names. A scope's parent is determined by finding a\n * scope ending with '*' that is a prefix of the current scope.\n *\n * The dictionary is organized into the following categories:\n * - `sign`: Scopes for signing operations (blob, transactions, etc.)\n * - `manage`: Scopes for management operations (keys, roles, policies, etc.)\n * - `export`: Scopes for export operations\n * - `mmi`: Scopes for MetaMask Integration\n * - `orgAccess`: Scopes for cross-organization access\n *\n * This dictionary serves as the source of truth for scope definitions and is used\n * to generate scopes for role and user sessions. It is also referenced by\n * {@link roleScopesDictionary} and {@link userScopesDictionary} which provide\n * filtered subsets of these scopes.\n *\n * @see {@link AllScopes} - The source record containing scope descriptions\n * @see {@link roleScopesDictionary} - Restricted scopes for role sessions\n * @see {@link userScopesDictionary} - Restricted scopes for user sessions\n */\nexport const allScopesDictionary: ScopesDictionary = computeScopesDictionary();\n\n/**\n * Restricted scopes dictionary for role-based session generation.\n * Contains only the scopes that are allowed for role sessions.\n */\nexport const roleScopesDictionary = {\n  sign: allScopesDictionary.sign,\n  mmi: allScopesDictionary.mmi,\n  manage: {\n    label: \"Manage\",\n    scopes: [\n      // Find and include manage:mmi:*\n      (allScopesDictionary.manage.scopes as ScopeItem[])\n        .find((s) => s.value === \"manage:*\")!\n        .children!.find((s) => s.value === \"manage:mmi:*\")!,\n      // Find and include manage:mfa:list\n      (allScopesDictionary.manage.scopes as ScopeItem[])\n        .find((s) => s.value === \"manage:*\")!\n        .children!.find((s) => s.value === \"manage:mfa:*\")!\n        .children!.find((s) => s.value === \"manage:mfa:list\")!,\n      // Find and include manage:key:get\n      (allScopesDictionary.manage.scopes as ScopeItem[])\n        .find((s) => s.value === \"manage:*\")!\n        .children!.find((s) => s.value === \"manage:key:*\")!\n        .children!.find((s) => s.value === \"manage:key:get\")!,\n      // Find and include manage:key:list\n      (allScopesDictionary.manage.scopes as ScopeItem[])\n        .find((s) => s.value === \"manage:*\")!\n        .children!.find((s) => s.value === \"manage:key:*\")!\n        .children!.find((s) => s.value === \"manage:key:list\")!,\n    ],\n  },\n} satisfies ScopesDictionary;\n\n/**\n * Restricted scopes dictionary for user session generation.\n * Excludes scopes that require elevated permissions (orgAccess, export).\n */\nexport const userScopesDictionary = {\n  manage: allScopesDictionary.manage,\n  sign: allScopesDictionary.sign,\n  mmi: allScopesDictionary.mmi,\n};\n"]}
|
|
332
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"scopes.js","sourceRoot":"","sources":["../../src/scopes.ts"],"names":[],"mappings":"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","sourcesContent":["// eslint-disable spaced-comment\n\nimport { type ExplicitScope } from \".\";\n\nexport type ScopesDictionary = Record<string, { label: string; scopes: ScopeItem[] }>;\n\nexport interface ScopeItem {\n  value: ExplicitScope;\n  description: string;\n  children?: ScopeItem[];\n}\n\n/** Mapping from scope name to scope description */\nexport const AllScopes: Record<ExplicitScope, string> =\n  // prettier-ignore\n  {\n  \"sign:*\"                                      : \"Allows access to all signer endpoints (e.g., sign blob, sign bitcoin/avalanche/evm transaction, etc.)\",\n  \"sign:ava\"                                    : \"Allows access to the sign 'ava' endpoint\",\n  \"sign:blob\"                                   : \"Allows access to the sign 'blob' endpoint\",\n  \"sign:diffieHellman\"                          : \"Allows access to the Diffie-Hellman endpoint. This is not really signing, but we put it under the `sign` hierarchy because it is conceptually similar.\",\n  \"sign:btc:*\"                                  : \"Allows access to all BTC endpoints\",\n  \"sign:btc:segwit\"                             : \"Allows access to the signing endpoint for segwit transactions\",\n  \"sign:btc:taproot\"                            : \"Allows access to the signing endpoint for taproot transactions\",\n  \"sign:btc:psbt:*\"                             : \"Allows access to the PSBT signing endpoint for any key type\",\n  \"sign:btc:psbt:doge\"                          : \"Allows access to the PSBT signing endpoint for Doge keys\",\n  \"sign:btc:psbt:legacy\"                        : \"Allows access to the PSBT signing endpoint for legacy keys\",\n  \"sign:btc:psbt:segwit\"                        : \"Allows access to the PSBT signing endpoint for segwit keys\",\n  \"sign:btc:psbt:taproot\"                       : \"Allows access to the PSBT signing endpoint for taproot keys\",\n  \"sign:btc:psbt:ltcSegwit\"                     : \"Allows access to the PSBT signing endpoint for Litecoin segwit keys\",\n  \"sign:btc:message:*\"                          : \"Allows access to the BTC message signing endpoint for any key type\",\n  \"sign:btc:message:segwit\"                     : \"Allows access to the BTC message signing endpoint for segwit keys\",\n  \"sign:btc:message:legacy\"                     : \"Allows access to the BTC message signing endpoint for legacy keys\",\n  \"sign:babylon:*\"                              : \"Allows access to all Babylon endpoints\",\n  \"sign:babylon:eots:*\"                         : \"Allows access to all Babylon EOTS endpoints\",\n  \"sign:babylon:eots:nonces\"                    : \"Allows access to the EOTS nonce generation endpoint\",\n  \"sign:babylon:eots:sign\"                      : \"Allows access to the EOTS signing endpoint\",\n  \"sign:babylon:staking:*\"                      : \"Allows access to the signing endpoint for all Babylon staking operations\",\n  \"sign:babylon:staking:deposit\"                : \"Allows access to the signing endpoint for Babylon deposits\",\n  \"sign:babylon:staking:unbond\"                 : \"Allows access to the signing endpoint for Babylon unbonding\",\n  \"sign:babylon:staking:withdraw\"               : \"Allows access to the signing endpoint for Babylon withdrawals\",\n  \"sign:babylon:staking:slash\"                  : \"Allows access to the signing endpoint for Babylon slashing pre-signatures\",\n  \"sign:babylon:registration\"                   : \"Allows access to the signing endpoint for Babylon registration\",\n  \"sign:babylon:covenant\"                       : \"Allows access to the signing endpoint for Babylon covenant signing\",\n  \"sign:evm:*\"                                  : \"Allows access to all sign 'evm' endpoints\",\n  \"sign:evm:tx\"                                 : \"Allows access to the signing endpoint for evm transactions\",\n  \"sign:evm:eip191\"                             : \"Allows access to the signing endpoint for EIP-191 personal_message data\",\n  \"sign:evm:eip712\"                             : \"Allows acess to the signing endpoint for EIP-712 typed data\",\n  \"sign:eth2:*\"                                 : \"Allows access to all sign 'eth2' endpoints\",\n  \"sign:eth2:validate\"                          : \"Allows access to the sign eth2 'validate' endpoint\",\n  \"sign:eth2:stake\"                             : \"Allows access to the sign eth2 'stake' endpoint\",\n  \"sign:eth2:unstake\"                           : \"Allows access to the sign eth2 'unstake' endpoint\",\n  \"sign:solana\"                                 : \"Allows access to the sign 'solana' endpoint\",\n  \"sign:sui\"                                    : \"Allows access to the sign 'sui' endpoint\",\n  \"sign:tendermint\"                             : \"Allows access to the sign 'tendermint' endpoint\",\n  \"sign:mmi\"                                    : \"Allows access to the sign 'mmi' endpoint\",\n  \"manage:*\"                                    : \"Allows access to all management endpoints (e.g., create role, create key, add key to role, etc.)\",\n  \"manage:readonly\"                             : \"Allows access to all management readonly endpoints\",\n  \"manage:email\"                                : \"Allows access only to the email management endpoints\",\n  \"manage:mfa:*\"                                : \"Allows access only to MFA endpoints (e.g., get/approve existing MFA request)\",\n  \"manage:mfa:readonly\"                         : \"Allows access only to MFA readonly endpoints (e.g., get/list existing MFA request(s))\",\n  \"manage:mfa:list\"                             : \"Allows access only to the MFA list endpoint (list existing MFA requests)\",\n  \"manage:mfa:vote:*\"                           : \"Allows access to all MFA vote endpoints (vote using current CubeSigner session, TOTP, or FIDO)\",\n  \"manage:mfa:vote:cs\"                          : \"Allows access only to the MFA 'vote with CubeSigner' endpoint\",\n  \"manage:mfa:vote:email\"                       : \"Allows access only to the MFA 'vote with email' endpoint\",\n  \"manage:mfa:vote:fido\"                        : \"Allows access only to the MFA 'vote with TOTP' endpoint\",\n  \"manage:mfa:vote:totp\"                        : \"Allows access only to the MFA 'vote with FIDO' endpoint\",\n  \"manage:mfa:register:*\"                       : \"Allows access to all MFA register endpoints\",\n  \"manage:mfa:register:fido\"                    : \"Allows access only to the MFA 'register TOTP' endpoint\",\n  \"manage:mfa:register:totp\"                    : \"Allows access only to the MFA 'register FIDO' endpoint\",\n  \"manage:mfa:register:email\"                   : \"Allows access only to the MFA 'register verified email' endpoint\",\n  \"manage:mfa:unregister:*\"                     : \"Allows access to all MFA unregister endpoints\",\n  \"manage:mfa:unregister:fido\"                  : \"Allows access only to the MFA 'delete TOTP' endpoint\",\n  \"manage:mfa:unregister:totp\"                  : \"Allows access only to the MFA 'delete FIDO' endpoint\",\n  \"manage:mfa:verify:*\"                         : \"Allows access to all MFA verify endpoints\",\n  \"manage:mfa:verify:totp\"                      : \"Allows access only to the MFA 'verify TOTP' endpoint\",\n  \"manage:key:*\"                                : \"Allows access to all key endpoints\",\n  \"manage:key:readonly\"                         : \"Allows access to all key readonly endpoints\",\n  \"manage:key:attest\"                           : \"Allows access only to the key 'attest' endpoint\",\n  \"manage:key:get\"                              : \"Allows access only to the key 'get' endpoint\",\n  \"manage:key:listRoles\"                        : \"Allows access only to the key 'listRoles' endpoint\",\n  \"manage:key:list\"                             : \"Allows access only to the key 'list' endpoint\",\n  \"manage:key:history:tx:list\"                  : \"Allows access only to the key 'list_historical_tx' endpoint\",\n  \"manage:key:create\"                           : \"Allows access only to key creation endpoints (e.g., 'create' and 'derive')\",\n  \"manage:key:import\"                           : \"Allows access only to the key 'import' endpoint\",\n  \"manage:key:update:*\"                         : \"Allows access only to the key 'update' endpoint, within which allowing all possible updates\",\n  \"manage:key:update:owner\"                     : \"Allows access only to the key 'update' endpoint, but restricting updates to the key owner property\",\n  \"manage:key:update:policy\"                    : \"Allows access only to the key 'update' endpoint, but restricting updates to the key policy property\",\n  \"manage:key:update:enabled\"                   : \"Allows access only to the key 'update' endpoint, but restricting updates to the key enabled property\",\n  \"manage:key:update:metadata\"                  : \"Allows access only to the key 'update' endpoint and restricts updates to the key metadata property\",\n  \"manage:key:update:editPolicy\"                : \"Allows access only to the key 'update' endpoint and restricts updates to the 'edit_policy' property\",\n  \"manage:key:delete\"                           : \"Allows access only to the key 'delete' endpoint\",\n  \"manage:policy:*\"                             : \"Allows access to all policy endpoints\",\n  \"manage:policy:create\"                        : \"Allows access only to the policy creation endpoint\",\n  \"manage:policy:get\"                           : \"Allows access only to the policy 'get' endpoint\",\n  \"manage:policy:list\"                          : \"Allows access only to the policy 'list' endpoint\",\n  \"manage:policy:delete\"                        : \"Allows access only to the policy `delete` endpoint\",\n  \"manage:policy:update:*\"                      : \"Allows access only to the policy 'update' endpoint, within which allowing all possible updates\",\n  \"manage:policy:update:acl\"                    : \"Allows access only to the policy 'update' endpoint, but restricting updates to the policy ACL\",\n  \"manage:policy:update:owner\"                  : \"Allows access only to the policy 'update' endpoint, but restricting updates to the policy owner property\",\n  \"manage:policy:update:name\"                   : \"Allows access only to the policy 'update' endpoint, but restricting updates to the policy name\",\n  \"manage:policy:update:editPolicy\"             : \"Allows access only to the policy 'update' endpoint, but restricting updates to the 'edit_policy' property\",\n  \"manage:policy:update:metadata\"               : \"Allows access only to the policy 'update' endpoint, but restricting updates to the 'metadata' property\",\n  \"manage:policy:update:rule\"                   : \"Allows access only to the policy 'update' endpoint, but restricting updates to the policy rule itself\",\n  \"manage:policy:invoke\"                        : \"Allows access only to the policy 'invoke' endpoint.\",\n  \"manage:policy:wasm:*\"                        : \"Allows access to all wasm policy endpoints\",\n  \"manage:policy:wasm:upload\"                   : \"Allows access only to the wasm policy 'upload' endpoint\",\n  \"manage:policy:secrets:*\"                     : \"Allows access to all policy secrets endpoints\",\n  \"manage:policy:secrets:get\"                   : \"Allows access only to the policy secrets 'get' endpoint\",\n  \"manage:policy:secrets:update:*\"              : \"Allows access to all policy secrets 'update' endpoints\",\n  \"manage:policy:secrets:update:values\"         : \"Allows access only to the policy secrets 'update' endpoint, but restricting updates to the secrets keys and values\",\n  \"manage:policy:secrets:update:editPolicy\"     : \"Allows access only to the policy secrets 'update' endpoint, but restricting updates to the `edit_policy` property\",\n  \"manage:contact:*\"                            : \"Allows access to all contact endpoints\",\n  \"manage:contact:create\"                       : \"Allows access to the contact 'create' endpoint\",\n  \"manage:contact:get\"                          : \"Allows access to the contact `get` endpoint\",\n  \"manage:contact:list\"                         : \"Allows access to the contact `list` endpoint\",\n  \"manage:contact:delete\"                       : \"Allows access to the contact `delete` endpoint\",\n  \"manage:contact:update:*\"                     : \"Allows access only to the contact 'update' endpoint\",\n  \"manage:contact:update:name\"                  : \"Allows access only to the contact 'update' endpoint, but restricts updates to the contact's 'name' field.\",\n  \"manage:contact:update:addresses\"             : \"Allows access only to the contact 'update' endpoint, but restricts updates to the contact's 'addresses' field.\",\n  \"manage:contact:update:owner\"                 : \"Allows access only to the contact 'update' endpoint, but restricts updates to the contact's 'owner' field.\",\n  \"manage:contact:update:metadata\"              : \"Allows access only to the contact 'update' endpoint, but restricts updates to the contact's 'metadata' field.\",\n  \"manage:contact:update:editPolicy\"            : \"Allows access only to the contact 'update' endpoint, but restricts updates to the contact's 'edit_policy' field.\",\n  \"manage:contact:lookup:*\"                     : \"Allows access to the contact `lookup` endpoints\",\n  \"manage:contact:lookup:address\"               : \"Allows access only to the contact 'lookup by address' endpoint\",\n  \"manage:policy:createImportKey\"               : \"Allows access only to the policy key endpoint\",\n  \"manage:role:*\"                               : \"Allows access to all role endpoints\",\n  \"manage:role:readonly\"                        : \"Allows access to all role readonly endpoints\",\n  \"manage:role:create\"                          : \"Allows access only to the role 'create' endpoint\",\n  \"manage:role:delete\"                          : \"Allows access only to the role 'delete' endpoint\",\n  \"manage:role:get:*\"                           : \"Allows access only to the role 'get' endpoint\",\n  \"manage:role:get:keys\"                        : \"Allows access to the role 'list keys' and 'get key' endpoints\",\n  \"manage:role:get:keys:list\"                   : \"Allows access to the role 'list keys' endpoint\",\n  \"manage:role:get:keys:get\"                    : \"Allows access to the role 'get key' endpoint\",\n  \"manage:role:get:users\"                       : \"Allows access to the role 'list users' endpoint\",\n  \"manage:role:list\"                            : \"Allows access only to the role 'list' endpoint\",\n  \"manage:role:update:*\"                        : \"Allows access only to the role 'update' endpoint\",\n  \"manage:role:update:enabled\"                  : \"Allows access only to the role 'update' endpoint, but restricting updates to the role 'enabled' property\",\n  \"manage:role:update:policy\"                   : \"Allows access only to the role 'update' endpoint, but restricting updates to the role 'policy' property\",\n  \"manage:role:update:editPolicy\"               : \"Allows access only to the role 'update' endpoint, but restricting updates to the role 'edit_policy' property\",\n  \"manage:role:update:key:*\"                    : \"Allows access to all role 'update:key' endpoints\",\n  \"manage:role:update:key:add\"                  : \"Allows access to the role 'update:keys:add' endpoint\",\n  \"manage:role:update:key:remove\"               : \"Allows access to the role 'update:keys:remove' endpoint\",\n  \"manage:role:update:user:*\"                   : \"Allows access to all role 'update:user' endpoints\",\n  \"manage:role:update:user:add\"                 : \"Allows access to the role 'update:user:add' endpoint\",\n  \"manage:role:update:user:remove\"              : \"Allows access to the role 'update:user:remove' endpoint\",\n  \"manage:role:history:tx:list\"                 : \"Allows access only to the role 'list_historical_tx' endpoint\",\n  \"manage:identity:*\"                           : \"Allows access to all identity endpoints\",\n  \"manage:identity:verify\"                      : \"Allows access only to the identity 'verify' endpoint\",\n  \"manage:identity:add\"                         : \"Allows access only to the identity 'add' endpoint\",\n  \"manage:identity:remove\"                      : \"Allows access only to the identity 'remove' endpoint\",\n  \"manage:identity:list\"                        : \"Allows access only to the identity 'list' endpoint\",\n  \"manage:org:*\"                                : \"Allows access to all org endpoints\",\n  \"manage:org:create\"                           : \"Allows access to the org 'create' endpoint\",\n  \"manage:org:metrics:query\"                    : \"Allows access to retrieving org metrics\",\n  \"manage:org:readonly\"                         : \"Allows access to all org readonly endpoints\",\n  \"manage:org:addUser\"                          : \"Allows access only to the org endpoint for adding an OIDC user to the org\",\n  \"manage:org:inviteUser\"                       : \"Allows access only to the org endpoint for inviting a new member or org owner to the org\",\n  \"manage:org:inviteAlien\"                      : \"Allows access only to the org endpoint for inviting a new alien user to the org\",\n  \"manage:org:updateMembership\"                 : \"Allows access only to the org endpoint for updating existing user's org membership\",\n  \"manage:org:listUsers\"                        : \"Allows access only to the org endpoint for listing all org users (members)\",\n  \"manage:org:user:get\"                         : \"Allows access only to the org endpoints for getting users by id or email\",\n  \"manage:org:deleteUser\"                       : \"Allows access only to the org endpoint for deleting an OIDC user\",\n  \"manage:org:get\"                              : \"Allows access to retrieving organization information\",\n  \"manage:org:user:resetMfa\"                    : \"Allows an owner to initiate an MFA reset for a user\",\n  \"manage:session:*\"                            : \"Allows access to all session endpoints\",\n  \"manage:session:readonly\"                     : \"Allows access to all session readonly endpoints\",\n  \"manage:session:get\"                          : \"Allows access only to the session 'get' endpoint\",\n  \"manage:session:list\"                         : \"Allows access only to the session 'list' endpoint\",\n  \"manage:session:create\"                       : \"Allows access only to the session 'create' endpoint, but without the ability to extend session lifetimes\",\n  \"manage:session:extend\"                       : \"Allows access only to the session 'create' endpoint, including the ability to extend session lifetimes\",\n  \"manage:session:revoke\"                       : \"Allows access only to the session 'revoke' endpoints\",\n  \"manage:export:*\"                             : \"Allows access to all export endpoints\",\n  \"manage:export:org:*\"                         : \"Allows access to all org-export management endpoints\",\n  \"manage:export:org:get\"                       : \"Allows access to the org-export download endpoint\",\n  \"manage:export:user:*\"                        : \"Allows access to all user-export management endpoints\",\n  \"manage:export:user:delete\"                   : \"Allows deleting an existing user-export request\",\n  \"manage:export:user:list\"                     : \"Allows listing existing user-export requests\",\n  \"manage:authMigration:*\"                      : \"Allows all auth migration scopes\",\n  \"manage:authMigration:identity:add\"           : \"Allows adding identities to existing users during an auth migration\",\n  \"manage:authMigration:identity:remove\"        : \"Allows removing identities from existing users during an auth migration\",\n  \"manage:authMigration:user:update\"            : \"Allows updating existing users' profiles\",\n  \"manage:mmi:*\"                                : \"Allows all CRUD operations on MMI pending messages\",\n  \"manage:mmi:readonly\"                         : \"Allows all readonly operations on MMI pending messages\",\n  \"manage:mmi:get\"                              : \"Allows retrieving MMI pending messages\",\n  \"manage:mmi:list\"                             : \"Allows listing MMI pending messages\",\n  \"manage:mmi:reject\"                           : \"Allows rejecting MMI pending messages\",\n  \"manage:mmi:delete\"                           : \"Allows deleting MMI pending messages\",\n  \"export:*\"                                    : \"Allows access to all export endpoints\",\n  \"export:user:*\"                               : \"Allows access to all user-export execution endpoints\",\n  \"export:user:init\"                            : \"Allows initiating a new user-export request\",\n  \"export:user:complete\"                        : \"Allows completing an existing user-export request\",\n  \"mmi:*\"                                       : \"Allows calls to the MMI endpoint\",\n  \"orgAccess:*\"                                 : \"Allows access to certain orgs other than the current session's\",\n  \"orgAccess:child:*\"                           : \"Allows a session to be used for access to orgs transitively parented by the session's org.\",\n};\n\n// Const for scope category labels\nconst CATEGORY_LABELS: Record<string, string> = {\n  sign: \"Sign\",\n  manage: \"Manage\",\n  export: \"Export\",\n  mmi: \"MMI\",\n  orgAccess: \"Org Access\",\n};\n\n/**\n * Finds the parent scope for a given scope.\n * A parent is a scope ending with '*' that is a prefix of the current scope.\n * Returns the longest matching parent (closest ancestor), excluding the scope itself.\n *\n * @param scope The scope to find the parent for.\n * @param allScopes The list of all scopes.\n * @returns The parent scope or null if no parent is found.\n */\nfunction findParent(scope: ExplicitScope, allScopes: ExplicitScope[]): ExplicitScope | null {\n  let parent: ExplicitScope | null = null;\n  let maxLength = 0;\n\n  for (const candidate of allScopes) {\n    // Skip the scope itself\n    if (candidate === scope) continue;\n\n    if (candidate.endsWith(\"*\") && scope.startsWith(candidate.slice(0, -1))) {\n      // Prefer the longest matching parent (closest ancestor)\n      if (candidate.length > maxLength) {\n        parent = candidate;\n        maxLength = candidate.length;\n      }\n    }\n  }\n\n  return parent;\n}\n\n/**\n * Computes the scopes dictionary from AllScopes.\n *\n * @returns The complete dictionary of all available scopes organized by category.\n */\nfunction computeScopesDictionary(): ScopesDictionary {\n  const allScopes = Object.keys(AllScopes) as ExplicitScope[];\n  const items = new Map<ExplicitScope, ScopeItem>();\n  const result: ScopesDictionary = {};\n\n  // First pass: create all items\n  for (const scope of allScopes) {\n    const category = scope.split(\":\")[0];\n    if (!result[category]) {\n      result[category] = { label: CATEGORY_LABELS[category] || category, scopes: [] };\n    }\n\n    items.set(scope, {\n      value: scope,\n      description: AllScopes[scope],\n      children: [],\n    });\n  }\n\n  // Second pass: build parent-child relationships\n  for (const scope of allScopes) {\n    const category = scope.split(\":\")[0];\n    const item = items.get(scope)!;\n    const parentScope = findParent(scope, allScopes);\n\n    if (parentScope && parentScope !== scope) {\n      items.get(parentScope)!.children!.push(item);\n    } else {\n      result[category].scopes.push(item);\n    }\n  }\n\n  // Sort roots: wildcards first\n  for (const category of Object.values(result)) {\n    category.scopes.sort((a, b) => {\n      if (a.value.endsWith(\"*\") && !b.value.endsWith(\"*\")) return -1;\n      if (!a.value.endsWith(\"*\") && b.value.endsWith(\"*\")) return 1;\n      return a.value.localeCompare(b.value);\n    });\n  }\n\n  return result;\n}\n\n/**\n * Complete dictionary of all available scopes organized by category.\n *\n * This dictionary is automatically computed from {@link AllScopes} by inferring\n * the hierarchy from scope names. A scope's parent is determined by finding a\n * scope ending with '*' that is a prefix of the current scope.\n *\n * The dictionary is organized into the following categories:\n * - `sign`: Scopes for signing operations (blob, transactions, etc.)\n * - `manage`: Scopes for management operations (keys, roles, policies, etc.)\n * - `export`: Scopes for export operations\n * - `mmi`: Scopes for MetaMask Integration\n * - `orgAccess`: Scopes for cross-organization access\n *\n * This dictionary serves as the source of truth for scope definitions and is used\n * to generate scopes for role and user sessions. It is also referenced by\n * {@link roleScopesDictionary} and {@link userScopesDictionary} which provide\n * filtered subsets of these scopes.\n *\n * @see {@link AllScopes} - The source record containing scope descriptions\n * @see {@link roleScopesDictionary} - Restricted scopes for role sessions\n * @see {@link userScopesDictionary} - Restricted scopes for user sessions\n */\nexport const allScopesDictionary: ScopesDictionary = computeScopesDictionary();\n\n/**\n * Restricted scopes dictionary for role-based session generation.\n * Contains only the scopes that are allowed for role sessions.\n */\nexport const roleScopesDictionary = {\n  sign: allScopesDictionary.sign,\n  mmi: allScopesDictionary.mmi,\n  manage: {\n    label: \"Manage\",\n    scopes: [\n      // Find and include manage:mmi:*\n      (allScopesDictionary.manage.scopes as ScopeItem[])\n        .find((s) => s.value === \"manage:*\")!\n        .children!.find((s) => s.value === \"manage:mmi:*\")!,\n      // Find and include manage:mfa:list\n      (allScopesDictionary.manage.scopes as ScopeItem[])\n        .find((s) => s.value === \"manage:*\")!\n        .children!.find((s) => s.value === \"manage:mfa:*\")!\n        .children!.find((s) => s.value === \"manage:mfa:list\")!,\n      // Find and include manage:key:get\n      (allScopesDictionary.manage.scopes as ScopeItem[])\n        .find((s) => s.value === \"manage:*\")!\n        .children!.find((s) => s.value === \"manage:key:*\")!\n        .children!.find((s) => s.value === \"manage:key:get\")!,\n      // Find and include manage:key:list\n      (allScopesDictionary.manage.scopes as ScopeItem[])\n        .find((s) => s.value === \"manage:*\")!\n        .children!.find((s) => s.value === \"manage:key:*\")!\n        .children!.find((s) => s.value === \"manage:key:list\")!,\n    ],\n  },\n} satisfies ScopesDictionary;\n\n/**\n * Restricted scopes dictionary for user session generation.\n * Excludes scopes that require elevated permissions (orgAccess, export).\n */\nexport const userScopesDictionary = {\n  manage: allScopesDictionary.manage,\n  sign: allScopesDictionary.sign,\n  mmi: allScopesDictionary.mmi,\n};\n"]}
|
package/package.json
CHANGED
|
@@ -5,7 +5,7 @@
|
|
|
5
5
|
"url": "git+https://github.com/cubist-labs/CubeSigner-TypeScript-SDK.git",
|
|
6
6
|
"directory": "packages/sdk"
|
|
7
7
|
},
|
|
8
|
-
"version": "0.4.
|
|
8
|
+
"version": "0.4.205",
|
|
9
9
|
"description": "CubeSigner TypeScript SDK",
|
|
10
10
|
"license": "MIT OR Apache-2.0",
|
|
11
11
|
"author": "Cubist, Inc.",
|
package/src/scopes.ts
CHANGED
|
@@ -206,18 +206,30 @@ const CATEGORY_LABELS: Record<string, string> = {
|
|
|
206
206
|
/**
|
|
207
207
|
* Finds the parent scope for a given scope.
|
|
208
208
|
* A parent is a scope ending with '*' that is a prefix of the current scope.
|
|
209
|
+
* Returns the longest matching parent (closest ancestor), excluding the scope itself.
|
|
209
210
|
*
|
|
210
211
|
* @param scope The scope to find the parent for.
|
|
211
212
|
* @param allScopes The list of all scopes.
|
|
212
213
|
* @returns The parent scope or null if no parent is found.
|
|
213
214
|
*/
|
|
214
215
|
function findParent(scope: ExplicitScope, allScopes: ExplicitScope[]): ExplicitScope | null {
|
|
216
|
+
let parent: ExplicitScope | null = null;
|
|
217
|
+
let maxLength = 0;
|
|
218
|
+
|
|
215
219
|
for (const candidate of allScopes) {
|
|
220
|
+
// Skip the scope itself
|
|
221
|
+
if (candidate === scope) continue;
|
|
222
|
+
|
|
216
223
|
if (candidate.endsWith("*") && scope.startsWith(candidate.slice(0, -1))) {
|
|
217
|
-
|
|
224
|
+
// Prefer the longest matching parent (closest ancestor)
|
|
225
|
+
if (candidate.length > maxLength) {
|
|
226
|
+
parent = candidate;
|
|
227
|
+
maxLength = candidate.length;
|
|
228
|
+
}
|
|
218
229
|
}
|
|
219
230
|
}
|
|
220
|
-
|
|
231
|
+
|
|
232
|
+
return parent;
|
|
221
233
|
}
|
|
222
234
|
|
|
223
235
|
/**
|